主页 > 知识库 > Linux下的Oracle启动脚本及其开机自启动

Linux下的Oracle启动脚本及其开机自启动

热门标签:开封智能外呼系统厂家 征服眼公司地图标注 阿尔巴尼亚地图标注app 人工智能地图标注自己能做吗 外呼线路外显本地号码 美图秀秀地图标注 word地图标注方向 征服者火车站地图标注 百度地图标注素材

说明:以下操作环境在CentOS 6.4 + Oracle 11gR2(Oracle安装在ORACLE_BASE=/opt/oracle中,其ORACLE_HOME=/opt/oracle/11g)

用OUI安装并配置Oracle数据库后,Oracle就开启了(包括:数据库实例、监听器、EM)。在重启操作系统之后,Oracle默认是没有启动的。使用如下命令查看Oracle相关服务是否已启动:

ps aux | grep ora_ #若无ora_**_**相关的进程,则oracle数据库实例未启动
netstat -tlnup | grep 1521 #若无任何显示,则监听器未启动
lsnrctl status #查看监听器状态
netstat -tlnup | grep 1158 #若无任何显示,则EM未启动
emctl status dbconsole #查看EM状态

手工启动Oracle实例,可用sqlplus建立一个idle instance,然后再用startup启动,如下:

数据库实例启动之后,需启动监听器,才能让远程用户建立连接。可使用如下命令启动监听器:

复制代码 代码如下:

lsnrctl start


Oracle还提供网页版的管理器,要使用该管理器需启动相关服务,使用如下命令启动:
复制代码 代码如下:

emctl start dbconsole

 

至此,可在web浏览器中输入:https://{主机IP 或 主机名 或 本地localhost}:1158/em,打开管理器,使用相关帐号登录进行数据库查看和管理。
如果每次重启操作系统都要进行以上操作好麻烦,那么如何让Oracle作为系统服务在开机的时候自动启动呢?
Oracle在$ORACLE_HOME/bin下提供许多对数据库进行操作的脚本,其中dbstart和dbshut可分别用来启动和关闭数据库。注意,这两个脚本已包含监听器的启动或关闭,但并未对EM进行相关的操作。使用如下命令:

复制代码 代码如下:

/opt/oracle/11g/bin/dbstart /opt/oracle/11g #启动数据库实例(包含监听器)
/opt/oracle/11g/bin/dbshut /opt/oracle/11g #关闭数据库实例(包括监听器)

以上命令要成功启动数据库实例还得打开Oracle设置的一个关卡:vi /etc/oratab,修改行:

复制代码 代码如下:

orcl:/opt/oracle/11g:Y #默认为orcl:/opt/oracle/11g:N

 

以root身份建立开机启动oracle服务的脚本:vi /etc/init.d/oracle,添加如下脚本:

复制代码 代码如下:

#!/bin/sh
#chkconfig: 2345 20 80
#description: Oracle dbstart / dbshut
#以上两行为chkconfig所需
ORA_HOME=/opt/oracle/11g
ORA_OWNER=oracle
LOGFILE=/var/log/oracle.log
echo "#################################" >> ${LOGFILE}
date +"### %T %a %D: Run Oracle" >> ${LOGFILE}
if [ ! -f ${ORA_HOME}/bin/dbstart ] || [ ! -f ${ORA_HOME}/bin/dbshut ]; then
    echo "Error: Missing the script file ${ORA_HOME}/bin/dbstart or ${ORA_HOME}/bin/dbshut!" >> ${LOGFILE}
    echo "#################################" >> ${LOGFILE}
    exit
fi
start(){
    echo "###Startup Database..."
    su - ${ORA_OWNER} -c "${ORA_HOME}/bin/dbstart ${ORA_HOME}"
    echo "###Done."
    echo "###Run database control..."
    su - ${ORA_OWNER} -c "${ORA_HOME}/bin/emctl start dbconsole"
    echo "###Done."
}
stop(){
    echo "###Stop database control..."
    su - ${ORA_OWNER} -c "${ORA_HOME}/bin/emctl stop dbconsole"
    echo "###Done."
    echo "###Shutdown Database..."
    su - ${ORA_OWNER} -c "${ORA_HOME}/bin/dbshut ${ORA_HOME}"
    echo "###Done."
}
case "$1" in
    'start')
        start >> ${LOGFILE}

    'stop')
        stop >> ${LOGFILE}

    'restart')
        stop >> ${LOGFILE}
        start >> ${LOGFILE}

esac
date +"### %T %a %D: Finished." >> ${LOGFILE}
echo "#################################" >> ${LOGFILE}
echo ""

 

使用如下命令将 /etc/init.d/oracle 置为可执行文件:

复制代码 代码如下:

chmod a+x /etc/init.d/oracle

 

至此,可使用如下命令对oracle进行启动和关闭

复制代码 代码如下:

/etc/init.d/oracle start #启动oracle(包括数据库实例、监听器、EM)
/etc/init.d/oracle stop #关闭oracle
/etc/init.d/oracle restart #重启oracle

 

将 oracle 添加到 chkconfig中:

复制代码 代码如下:

chkconfig --add oracle

 

可使用如下命令查看和设置oracle服务的开机启动级别

复制代码 代码如下:

chkconfig | grep oracle #查看oracle服务的开机启动级别
chkconfig --level 24 oracle off #修改oracle服务的开机启动级别
chkconfig --level 35 oracle on

 

至此可使用如下命令对oracle的启动或关闭进行管理

复制代码 代码如下:

service oracle start #启动
service oracle stop #关闭
service oracle restart #重启

建立连接:

复制代码 代码如下:

ln -s /etc/init.d/oracle /etc/rc0.d/K01oracle   #关机执行
ln -s /etc/init.d/oracle /etc/rc6.d/K01oracle   #重启执行

您可能感兴趣的文章:
  • linux设置服务开机自启动的三种方式
  • linux下oracle设置开机自启动实现方法
  • Linux中Oracle服务启动和停止脚本与开机自启动
  • Linux中设置Redis开机启动的方法
  • Linux 添加开机启动方法(服务/脚本)
  • linux开机启动nodemanager步骤
  • Linux下Redis设置密码及开机自启动
  • Linux开机启动过程详解
  • linux 开机自启动redis服务的方法
  • Linux系统设置开机自动运行脚本的方法实例

标签:葫芦岛 孝感 泰安 宜春 淮南 六安 酒泉 海北

巨人网络通讯声明:本文标题《Linux下的Oracle启动脚本及其开机自启动》,本文关键词  Linux,下的,Oracle,启动,脚本,;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 下面列出与本文章《Linux下的Oracle启动脚本及其开机自启动》相关的同类信息!
  • 本页收集关于Linux下的Oracle启动脚本及其开机自启动的相关信息资讯供网民参考!
  • 推荐文章