如何让oracle DB、监听和oem开机启动(dbstart)

简介:

如何让oracle DB、监听和oem开机启动(dbstart)





oracle DB、监听和oem开机启动(dbstart)

Oracle提供了伴随操作系统自动重启的功能,在Windows中,可以修改“我的电脑-->管理-->服务-->OracleService$ORACLE_SID”,或直接使用Win+R键打开运行窗口,输入services.msc即可打开服务,找到相应的Oracle服务,然后将其属性中的启动类型修改成自动。一般在Windows系统上安装完后会自动设置成自动。

对于Linux/Unix操作系统,如果想设置自动重启,那该如何操作呢?对此Oracle提供了dbstart命令用于启动,可以有2种方法来配置。


1.1.1.1     方法1:配置Linux的service服务

1. 修改/etc/oratab

[root@oracle ~]#vim /etc/oratab

orcl:/u01/app/oracle/product/11.2.0/dbhome_1:Y     #将N改为Y


文件/etc/oratabroot.sh脚本创建,在用DBCA创建实例时也会更新这个文件。当$ORACLE_SID:$ORACLE_HOME:<N|Y>设置为Y时,允许实例自启动,当设置为N时,则不允许自启动。这个文件里的配置仅仅起一个开关的作用,其并不会具体的执行启动和关闭,具体的操作由$ORACLE_HOME/bin/dbstartdbshut脚本来实现。这2个脚本在执行时会检查/etc/oratab文件里的配置,为Y时才能继续执行。


   2. 修改$ORACLE_HOME/bin/dbstart和$ORACLE_HOME/bin/dbshut


[root@oracle ~]#vim $ORACLE_HOME/bin/dbstart

[root@oracle ~]#vim $ORACLE_HOME/bin/dbshut

ORACLE_HOME_LISTNER=$ORACLE_HOME ($1改为$ORACLE_HOME)


ORACLE_HOME_LISTNER的位置:Oracle 11gdbstart在第80行,dbshut文件中在第50行。

3. 建立启动脚本

使用root用户创建脚本:

[root@oracle ~]#vim /etc/rc.d/init.d/oracle

#!/bin/bash

# chkconfig: 2345 99 10

# description: Startup Script for oracle Databases

# /etc/rc.d/init.d/oracle

 

export ORACLE_BASE=/u01/app/oracle/

export ORACLE_HOME=/u01/app/oracle/product/11.2.0/dbhome_1

export PATH=$PATH:$ORACLE_HOME/bin

export ORACLE_UNQNAME=PROD1

 

echo " " >> /var/log/oraclelog

echo `date +'%Y-%m-%d %H:%M:%S'` >> /var/log/oraclelog

 

case "$1" in

start)

echo "-----startup oracle-----" >> /var/log/oraclelog

su oracle -c "$ORACLE_HOME/bin/dbstart"

su oracle -c "$ORACLE_HOME/bin/emctl start dbconsole"

touch /var/lock/subsys/oracle

echo `date +'%Y-%m-%d %H:%M:%S'` >> /var/log/oraclelog

echo "-----startup oracle successful-----" >> /var/log/oraclelog

echo "OK"

;;

 

stop)

echo "-----shutdown oracle-----" >> /var/log/oraclelog

su oracle -c "$ORACLE_HOME/bin/dbshut"

su oracle -c "$ORACLE_HOME/bin/emctl stop dbconsole"

rm -f /var/lock/subsys/oracle

echo `date +'%Y-%m-%d %H:%M:%S'` >> /var/log/oraclelogg

echo "-----shutdown oracle successful-----" >> /var/log/oraclelog

echo "OK"

;;

 

restart)

echo "-----shutdown oracle-----" >> /var/log/oraclelog

su oracle -c "$ORACLE_HOME/bin/dbshut"

su oracle -c "$ORACLE_HOME/bin/emctl stop dbconsole"

rm -f /var/lock/subsys/oracle

echo `date +'%Y-%m-%d %H:%M:%S'` >> /var/log/oraclelog

echo "-----shutdown oracle successful-----" >> /var/log/oraclelog

 

echo "-----startup oracle-----" >> /var/log/oraclelog

su oracle -c "$ORACLE_HOME/bin/dbstart"

su oracle -c "$ORACLE_HOME/bin/emctl start dbconsole"

touch /var/lock/subsys/oracle

echo `date +'%Y-%m-%d %H:%M:%S'` >> /var/log/oraclelog

echo "-----startup oracle successful-----" >> /var/log/oraclelog

echo "OK"

;;

 

*)

echo "Usage: 'basename $0' start|stop|restart"

exit 1

esac

exit 0


4. 给脚本设置权限

[root@oracle ~]# chmod 755 /etc/rc.d/init.d/oracle



5. 建立服务

[root@oracle ~]# chkconfig --add oracle

[root@oracle ~]# chkconfig oracle on

[root@oracle ~]# chkconfig --list oracle

oracle          0:off   1:off   2:on    3:on    4:on    5:on    6:off

 

 

6. 检查是否生效

先使用root用户测试服务是否生效:

[root@edsir4p1 ~]# service oracle stop

[root@edsir4p1 ~]# service oracle start

[root@edsir4p1 ~]# service oracle restart

 

再重启OS,验证是否生效。

 

 

使用service测试:

[root@edsir4p1 ~]# service oracle stop

Processing Database instance "PROD1": log file /u01/app/oracle/product/11.2.0/dbhome_1/shutdown.log

Processing Database instance "PROD2": log file /u01/app/oracle/product/11.2.0/dbhome_1/shutdown.log

Oracle Enterprise Manager 11g Database Control Release 11.2.0.1.0

Copyright (c) 1996, 2009 Oracle Corporation.  All rights reserved.

https://edsir4p1.us.oracle.com:1158/em/console/aboutApplication

Stopping Oracle Enterprise Manager 11g Database Control ...

 ...  Stopped.

OK

[root@edsir4p1 ~]# service oracle start

Processing Database instance "PROD1": log file /u01/app/oracle/product/11.2.0/dbhome_1/startup.log

Processing Database instance "PROD2": log file /u01/app/oracle/product/11.2.0/dbhome_1/startup.log

Oracle Enterprise Manager 11g Database Control Release 11.2.0.1.0

Copyright (c) 1996, 2009 Oracle Corporation.  All rights reserved.

https://edsir4p1.us.oracle.com:1158/em/console/aboutApplication

Starting Oracle Enterprise Manager 11g Database Control ..... started.

------------------------------------------------------------------

Logs are generated in directory /u01/app/oracle/product/11.2.0/dbhome_1/edsir4p1.us.oracle.com_PROD1/sysman/log

OK


1.1.1.2     方法2:配置/etc/rc.d/rc.local文件

1. 修改/etc/oratab

[root@oracle ~]#vim /etc/oratab

orcl:/u01/app/oracle/product/11.2.0/dbhome_1:Y     #将N改为Y


  2. 修改$ORACLE_HOME/bin/dbstart和$ORACLE_HOME/bin/dbshut

[root@oracle ~]#vim $ORACLE_HOME/bin/dbstart

[root@oracle ~]#vim $ORACLE_HOME/bin/dbshut

ORACLE_HOME_LISTNER=$ORACLE_HOME ($1改为$ORACLE_HOME)


ORACLE_HOME_LISTNER的位置:Oracle 11gdbstart在第80行,dbshut文件中在第50行。


3. 建立启动脚本


将以下脚本添加到/etc/rc.d/rc.local或/etc/rc.local文件中(/etc/rc.local/etc/rc.d/rc.local的软连接文件):

export ORACLE_HOME=/u01/app/oracle/product/11.2.0/dbhome_1

su oracle -c $ORACLE_HOME/bin/dbstart

export ORACLE_UNQNAME=PROD1

su oracle -c "$ORACLE_HOME/bin/emctl start dbconsole"

若环境中没有创建EM,则可以不用添加ORACLE_UNQNAME,和emctl2行。

需要注意的是,/etc/rc.local/etc/rc.d/rc.local的软连接文件,如下所示:

[oracle@edsir4p1-PROD1 ~]$ ll /etc/rc.local

lrwxrwxrwx 1 root root 13 Aug 31  2013 /etc/rc.local -> rc.d/rc.local

[oracle@edsir4p1-PROD1 ~]$ ll /etc/rc.d/rc.local

-rwxr-xr-x 1 root root 401 Jan  2 03:51 /etc/rc.d/rc.local

 


4. 检查是否生效

先使用root用户测试服务是否生效:

[root@edsir4p1 ~]# export ORACLE_HOME=/u01/app/oracle/product/11.2.0/dbhome_1

[root@edsir4p1 ~]# su oracle -c $ORACLE_HOME/bin/dbstart

 

Processing Database instance "PROD1": log file /u01/app/oracle/product/11.2.0/dbhome_1/startup.log

Processing Database instance "PROD2": log file /u01/app/oracle/product/11.2.0/dbhome_1/startup.log

 

再重启OS,验证是否生效。

 




1.1.1.3     总结

 

对于这2种方法,需要注意的几个问题:


1. 多个实例都会自动重启。

2. 监听也会自动重启。

3. 重启的详细日志为:$ORACLE_HOME/shutdown.log和$ORACLE_HOME/startup.log。

4. oracle用户的环境变量可以不用配置。

5. ORACLE_UNQNAME的作用是设置EM的环境变量,emctl是启动OEM,若没有则可以不用设置。

6. ORACLE_HOME的作用是设置数据库监听的环境变量。

7. 对于ASMRAC环境,只需要将数据库资源注册的CRS中,即可实现开机启动。



 






     本文转自lhrbest 51CTO博客,原文链接:http://blog.51cto.com/lhrbest/2056644,如需转载请自行联系原作者


相关文章
|
7月前
|
Oracle 关系型数据库 Linux
Oracle设置监听之Navicat的锅
Oracle设置监听之Navicat的锅
103 0
|
Oracle 关系型数据库 Java
云服务器安装oracle修改IP地址监听器报错问题
当在云服务器中安装oracle时,按照一般的安装步骤安装后,需要修改两个文件的iIP地址才可以在本机进行访问,修改注意点: 监听器部分不要改成服务器的公网IP,要改成服务器的计算机名字才可以,两个配置文件夹均要修改
114 0
|
SQL Oracle 关系型数据库
Polar DB-O (兼容 Oracle 语法版本)和Polar DB PostgreSQL 版本概述(二)
Polar DB-O (兼容 Oracle 语法版本)和Polar DB PostgreSQL 版本概述(二)
1824 0
|
监控 Oracle 网络协议
干货速看!CentOS7+Oracle 19c安装并开启IPv6监听,带你一文打尽。
近日,工信部印发了关于贯彻落实《推进IPv6规模部署行动计划》的通知,额。。。不好意思,跑题了!其实也没有跑题,本篇就是想要讲跟IPV6有关的东西。现在很多最新版的组件都默认支持IPV6了,比如Nginx、PHP、MySQL等等。那么本篇专门讲解一下Oracle 19C如何开启对IPV6的支持,从安装到配置、到IPV6监听的配置,一文打尽。
395 0
|
Oracle 安全 关系型数据库
ORACLE 11g【安装流程】及部门问题解决,ORA-12514: TNS:监听程序当前无法识别连接描述符中请求的服务 下
ORACLE 11g【安装流程】及部门问题解决,ORA-12514: TNS:监听程序当前无法识别连接描述符中请求的服务 下
233 0
ORACLE 11g【安装流程】及部门问题解决,ORA-12514: TNS:监听程序当前无法识别连接描述符中请求的服务   下
|
SQL Oracle 关系型数据库
ORACLE 11g【安装流程】及部门问题解决,ORA-12514: TNS:监听程序当前无法识别连接描述符中请求的服务 上
ORACLE 11g【安装流程】及部门问题解决,ORA-12514: TNS:监听程序当前无法识别连接描述符中请求的服务 上
518 0
ORACLE 11g【安装流程】及部门问题解决,ORA-12514: TNS:监听程序当前无法识别连接描述符中请求的服务   上
|
Oracle 关系型数据库
oracle学习21-修改为静态监听
oracle学习21-修改为静态监听
107 0
oracle学习21-修改为静态监听
|
Oracle 关系型数据库
oracle学习3-配置监听
oracle学习3-配置监听
128 0
oracle学习3-配置监听
|
Oracle 关系型数据库
oracle学习49-监听服务设置开机自启,不用一直配置监听
oracle学习49-监听服务设置开机自启,不用一直配置监听
119 0
oracle学习49-监听服务设置开机自启,不用一直配置监听