日期:2014-05-16  浏览次数:20902 次

Linux 下Oracle11g 自动启动

安装完毕 Oracle 11g 每次都得手动启动 | 停止数据库(dbstart | dbshut)、监听器(lsnrctl)、控制(emtcl)。?

设置一下,若手动启动数据库的同时监听器没有启动(即启动数据库时自动启动监听器,停止数据库时停止监听器),则需要修改 dbstart? 脚本文件

[root@oracle bin]# vi dbstart

找到此段话,在最前端

# First argument is used to bring up Oracle Net Listener
ORACLE_HOME_LISTNER=$1??????
//需要将此处的 ORACLE_HOME_LISTNER=$1 修改为 ORACLE_HOME_LISTNER=$ORACLE_HOME
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

[root@oracle bin]# vi dbshut

# The? this to bring down Oracle Net Listener
ORACLE_HOME_LISTNER=$1
//需要将此处的 ORACLE_HOME_LISTNER=$1 修改为 ORACLE_HOME_LISTNER=$ORACLE_HOME
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

在启动了Linux系统之后,转到? /etc/init.d? 目录下;

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

?????? 使用 vi 命令,新建一个以 oracle 命名的文件(并将以下代码复制至文件中)

[root@oracle init.d]# vi oracle

#!/bin/sh
# chkconfig: 345 61 61
# description: Oracle 11g AutoRun Services
# /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=iboxpay
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 shutdow

?????? 在编辑完成之后,使用 :x? 命令保存此文件。

赋予执行权限

[root@myhome init.d]# chmod 750 /etc/init.d/oracle

链接:

[root@myhome init.d]# ln -s /etc/init.d/oracle /etc/rc1.d/K61oracle

[root@myhome init.d]# ln -s /etc/init.d/oracle /etc/rc3.d/S61oracle

执行以下命令:

[root@myhome init.d]# chkconfig --level 345 oracle on

[root@myhome init.d]# chkconfig --add oracle???????? //添加到服务里

?

?

?

注解

?

linux中chkconfig命令详解?

?

chkconfig:
??? chkconfig命令主要用来更新(启动或停止)和查询系统服务的运行级信息。谨记chkconfig不是立即自动禁止或激活一个服务,它只是简单的改变了符号连接。
语法:
??? chkconfig --list [name]
??? chkconfig --add name
??? chkconfig --del name
??? chkconfig [--level levels] name <on|off|reset>
??? chkconfig [--level levels] name

??? chkconfig 没有参数运行时,显示用法。如果加上服务名,那么就检查这个服务是否在当前运行级启动。如果是,返回true,否则返回false。如果在服务名后面指定了on,off或者reset,那么chkconfi 会改变指定服务的启动信息。on和off分别指服务被启动和停止,reset指重置服务的启动信息,无论有问题的初始化脚本指定了什么。on和off开关,系统默认只对运行级3,4,5有效,但是reset可以对所有运行级有效。
??? --level选项可以指定要查看的运行级而不一定是当前运行级。
??? 需要说明的是,对于每个运行级,只能有一个启动脚本或者停止脚本。当切换运行级时,init不会重新启动已经启动的服务,也不会再次去停止已经停止的服务。

??? chkconfig --list :显示所有运行级系统服务的运行状态信息(on或off)。如果指定了name,那么只显示指定的服务在不同运行级的状态。
??? chkconfig --add name:增加一项新的服务。chkconfig确保每个运行级有一项启动(S)或者杀死(K)入口。如有缺少,则会从缺省的init脚本自动建立。
??? chkconfig --del name:删除服务,并把相关符号连接从/etc/rc[0-6].d删除。
??? chkconfig [--level levels] name <on|off|reset>:设置某一服务在指定的运行级是被启动,停止还是重置。例如,要在3,4,5运行级停止nfs服务,则命令如下:
??? chkconfig --level 345 nfs off
运行级文件:
??? 每个被chkconfig管理的服务需要在对应的init.d下的脚本加上两行或者更多行的注释。第一行告诉chkconfig缺省启动的运行级以及启动和停止的优先级。如果某服务缺省不在任何运行级启动,那么使用 - 代替运行级。第二行对服务进行描述,可以用\ 跨行注释。
例如,random.init包含三行:
# chkconfig: 2345 20 80
# description: Saves and restores system entropy pool for \
# higher quality random number gener