CentOS Linux下配置Oracle 11gR2为系统服务自动启动

浏览: 3979
在Windows下安装完成Oracle 11gR2后,默认就开机自启动Oracle相关服务,但Linux下安装完后每次都得手动启动和关闭数据库(dbstart | dbshut)、监听器(lsnrctl)、控制台(emtcl)。如何把Oracle添加到Linux系统服务里开机自启动呢?下面以CentOS 6.3为例详解,其他发行版一样通用!

1、Redhat init简介
Linux启动时,会运行一个init程序,然后由init来启动后面的任务,包括多用户环境(inittab中设定)和网络等。运行级就是当前程序运行的功能级别,这个级别从1到6,具有不同的功能。这些级别在/etc/inittab(其他发行版这个文件位置不同)中指定,该文件就是init程序寻找的主要文件。最先运行的服务放在/etc/rc.d目录下。

文件以S开头,代表start(启动),后面的数字是启动顺序;文件以K开头,代表kill(结束),同样,后面的数字代表结束顺序。例如:/etc/rc3.d/S55sshd表示它与运行级别3有关,55就是它的启动顺序;/etc/rc3.d/K15nginx表示它与运行级别3有关,15就是它的关闭顺序。
init.d
这个目录中存放了一些服务启动脚本,系统安装时的多个rpm包,这些脚本在执行时可以用来启动,停止和重启这些服务。
rcx.d(x为0~6)
这个目录是启动级别的执行程序链接目录,里面的文件都是指向init.d目录中文件的一些软连接。

2、修改dbstart和dbshut启动关闭脚本,使其启动数据库的同时也自动启动监听器(即启动数据库时启动监听器,停止数据库时停止监听器):
修改dbstart中的 ORACLE_HOME_LISTNER=$1 修改为 ORACLE_HOME_LISTNER=$ORACLE_HOME
|# vim /u01/app/oracle/product/11.2.0/db_1/bin/dbstart
找到下面的代码,在实际脚本代码的前面
|# First argument is used to bring up Oracle Net Listener
ORACLE_HOME_LISTNER=$1
|# [b]将此处的 ORACLE_HOME_LISTNER=$1 修改为 ORACLE_HOME_LISTNER=$ORACLE_HOME[/b]
if [ ! $ORACLE_HOME_LISTNER ] ; then
echo "ORACLE_HOME_LISTNER is not SET, unable to auto-start Oracle Net Listener"
echo "Usage: $0 ORACLE_HOME"
else
LOG=$ORACLE_HOME_LISTNER/listener.log


修改dbshut中的 ORACLE_HOME_LISTNER=$1 修改为 ORACLE_HOME_LISTNER=$ORACLE_HOME
同样也修改dbshut脚本:
|# vim /u01/app/oracle/product/11.2.0/db_1/bin/dbshut
|# The this to bring down Oracle Net Listener
ORACLE_HOME_LISTNER=$1
|# [b]将此处的 ORACLE_HOME_LISTNER=$1 修改为 ORACLE_HOME_LISTNER=$ORACLE_HOME[/b]
if [ ! $ORACLE_HOME_LISTNER ] ; then
echo "ORACLE_HOME_LISTNER is not SET, unable to auto-stop Oracle Net Listener"
echo "Usage: $0 ORACLE_HOME"
else
LOG=$ORACLE_HOME_LISTNER/listener.log



3、要成功启动数据库实例还得打开Oracle设置的一个关卡:vi /etc/oratab,修改行:
orcl:/opt/oracle/11g:Y #默认为orcl:/opt/oracle/11g:N



4、以root身份建立开机启动oracle服务的脚本(新建Oracle服务启动脚本):vi /etc/init.d/oracle,添加如下脚本:
新建一个以oracle命名的文件(也可以命名为oracle11g等),并将以下脚本代码复制到文件里(里面的oracle目录路径根据自己的实际安装路径修改):
|#!/bin/sh
|# chkconfig: 345 61 61
|# description: Oracle 11g R2 AutoRun Servimces
|# /etc/init.d/oracle
|#
|# Run-level Startup script for the Oracle Instance, Listener, and
|# Web Interface

export ORACLE_BASE=/u01/app/oracle
export ORACLE_HOME=$ORACLE_BASE/product/11.2.0/db_1
export ORACLE_SID=ORCL
export PATH=$PATH:$ORACLE_HOME/bin

ORA_OWNR="oracle"

|# if the executables do not exist -- display error

if [ ! -f $ORACLE_HOME/bin/dbstart -o ! -d $ORACLE_HOME ]
then
echo "Oracle startup: cannot start"
exit 1
fi

|# depending on parameter -- startup, shutdown, restart
|# of the instance and listener or usage display

case "$1" in
start)
|# Oracle listener and instance startup
su $ORA_OWNR -lc $ORACLE_HOME/bin/dbstart
echo "Oracle Start Succesful!OK."
;;
stop)
|# Oracle listener and instance shutdown
su $ORA_OWNR -lc $ORACLE_HOME/bin/dbshut
echo "Oracle Stop Succesful!OK."
;;
reload|restart)
$0 stop
$0 start
;;
*)
echo $"Usage: `basename $0` {start|stop|reload|reload}"
exit 1
esac
exit 0




保存退出

5、赋予启动脚本执行权限并链接好
[root@localhost ~]# chmod 777 /etc/init.d/oracle
[root@localhost ~]# ln -s /etc/init.d/oracle /etc/rc1.d/K61oracle
[root@localhost ~]# ln -s /etc/init.d/oracle /etc/rc3.d/S61oracle



6、可使用如下命令对oracle进行启动和关闭
[root@localhost ~]# /etc/init.d/oracle start #启动oracle(包括数据库实例、监听器、EM)
[root@localhost ~]# /etc/init.d/oracle stop #关闭oracle
[root@localhost ~]# /etc/init.d/oracle restart #重启oracle



7、把oracle启动脚本添加到系统服务里并设置自启动
[root@localhost ~]# chkconfig --add oracle
[root@localhost ~]# chkconfig --level 345 oracle on



8、reboot重启系统,查看Oracle进程
[root@localhost ~]# ps -ef | grep oracle
[root@localhost ~]# chkconfig | grep oracle #查看oracle服务的开机启动级别



9、使用如下命令对oracle的启动或关闭进行管理
[root@localhost ~]# service oracle start #启动
[root@localhost ~]# service oracle stop #关闭
[root@localhost ~]# service oracle restart #重启



10、参考文献
Centos linux下配置oracle11G自动启动服务 http://www.ha97.com/4862.html
Linux下建立Oracle服务及其开机自启动 http://www.cnblogs.com/mophee/ ... .html
推荐 0
本文由 梁勇 创作,采用 知识共享署名-相同方式共享 3.0 中国大陆许可协议 进行许可。
转载、引用前需联系作者,并署名作者且注明文章出处。
本站文章版权归原作者及原出处所有 。内容为作者个人观点, 并不代表本站赞同其观点和对其真实性负责。本站是一个个人学习交流的平台,并不用于任何商业目的,如果有任何问题,请及时联系我们,我们将根据著作权人的要求,立即更正或者删除有关内容。本站拥有对此声明的最终解释权。

0 个评论

要回复文章请先登录注册