linux下系统开机oracle自启动(方法一) ---加载为服务自启动、停止
一、dbstart   及   dbshut

1. 修改Oracle系统配置文件:/etc/oratab,只有这样,Oracle 自带的dbstart和dbshut才能够发挥作用。

# vi /etc/oratab
orcl:/opt/oracle/102:Y

#Entries are of the form:
#$ORACLE_SID:$ORACLE_HOME:<N|Y>

Oracle数据库的自动启动及停止可籍Oracle提供的dbstart及dbshut。
这些文件又耍依靠 /etc/oratab存在才能使用(虽然更改dbshut和dbstart可解除这限制。)    
   
/etc/oratab格式如下:    
--------------------------------------------------------------------------------  
SID:ORACLE_HOME:AUTO  
--------------------------------------------------------------------------------
例如
--------------------------------------------------------------------------------
*:/opt/oracle9/product/9.2.0.4:N
boss:/opt/oracle9/product/9.2.0.4:Y
--------------------------------------------------------------------------------

二、 init.d   及   rc.d  
要在开机关机时自动启动和结束数据库的话,你需要修改   Linux   的启动脚本文件。这并不困难,不过,我需要指出这些改动因应不同的   Linux   发行版本(slackware,   debian,   redhat   等)而有所不同。
我这些例子适用于   Redhat   5.0。
要为你所用的   Linux   作出修改。
   
首先,我们要建立会执行   /etc/rc.d/init.d   目录中   dbshut   及   dbstart   的脚本文件。把以下文件命名为   /etc/rc.d/init.d/oracle:    
 
#############################################################

#chkconfig:2345 98 05
#description:Oracle Server

#add for oracle
ORACLE_BASE=/opt/oracle9
export ORACLE_BASE
ORACLE_HOME=$ORACLE_BASE/product/9.2.0.4
export ORACLE_HOME
ORACLE_SID=BOSS
export ORACLE_SID
ORA_NLS33=$ORACLE_HOME/ocommon/nls/admin/data
export ORA_NLS33
NLS_LANG=american_america.zhs16gbk
export NLS_LANG
LD_LIBRARY_PATH=$LD_LIBRARY_PATH:$ORACLE_HOME/lib
export LD_LIBRARY_PATH

case "$1" in
        start)
                echo "Starting Oracle..."
                su oracle -c "/opt/oracle9/product/9.2.0.4/bin/lsnrctl start"
                su oracle -c "/opt/oracle9/product/9.2.0.4/bin/dbstart 1>$ORACLE_HOME/bin/dbstart.log  2>$ORACLE_HOME/bin/dbstart.err"
                echo "Started."
exit 0
;;
        stop)
                echo "Stoping Oracle..."
                su oracle -c "/opt/oracle9/product/9.2.0.4/bin/lsnrctl stop"
                su oracle -c "/opt/oracle9/product/9.2.0.4/bin/dbshut"
                echo "Stoped."
exit 0
;;

*)
echo "Usage: $0 {start|stop}"
exit 1

esac

#############################################################

下面是另一SHELL的
--------------------------------------------------------------------------------   
    
#!/bin/sh   
#   
#chkconfig:2345 98 05
#description:Oracle Server
#/etc/rc.d/init.d/oracle   
#解说∶启动及停止   Oracle   数据库和监听程序   
#检查如何执行脚本文件   
case   "$1"   in   
      start)   
                  echo   -n   "Starting   Oracle   Databases:   "   
                  echo   "----------------------------------------------------"   >>   /var/log/oracle   
                  date   +"!   %T   %a   %D   :   Starting   Oracle   Databases   as   part   of   system   up."   >>   /var/log/oracle   
                  echo   "----------------------------------------------------"   >>   /var/log/oracle   
                  su   -   oracle   -c   dbstart   >>   /var/log/oracle   
                  echo   "Done."   
                  echo   -n   "Starting   Oracle   Listeners:   "   
                  su   -   oracle   -c   "lsnrctl   start"   >>   /var/log/oracle   
                  echo   "Done."   
                  echo   ""   
                  echo   "----------------------------------------------------"   >>   /var/log/oracle   
                  date   +"!   %T   %a   %D   :   Finished."   >>   /var/log/oracle   
                  echo   "----------------------------------------------------"   >>   /var/log/oracle   
                  touch   /var/lock/subsys/oracle   
                  ;;   
      stop)   
                  echo   -n   "Shutting   Down   Oracle   Listeners:   "   
                  echo   "----------------------------------------------------"   >>   /var/log/oracle   
                  date   +"!   %T   %a   %D   :   Shutting   Down   Oracle   Databases   as   part   of   system   down."   >>   /var/log/oracle   
                  echo   "----------------------------------------------------"   >>   /var/log/oracle   
                  su   -   oracle   -c   "lsnrctl   stop"   >>   /var/log/oracle   
                  echo   "Done."   
                  rm   -f   /var/lock/subsys/oracle   
                  echo   -n   "Shutting   Down   Oracle   Databases:   "   
                  su   -   oracle   -c   dbshut   >>   /var/log/oracle   
                  echo   "Done."   
                  echo   ""   
                  echo   "----------------------------------------------------"   >>   /var/log/oracle   
                  date   +"!   %T   %a   %D   :   Finished."   >>   /var/log/oracle   
                  echo   "----------------------------------------------------"   >>   /var/log/oracle   
                  ;;   
      restart)   
                  echo   -n   "Restarting   Oracle   Databases:   "   
                  echo   "----------------------------------------------------"   >>   /var/log/oracle   
                  date   +"!   %T   %a   %D   :   Restarting   Oracle   Databases   as   part   of   system   up."   >>   /var/log/oracle   
                  echo   "----------------------------------------------------"   >>   /var/log/oracle   
                  su   -   oracle   -c   dbstop   >>   /var/log/oracle   
                  su   -   oracle   -c   dbstart   >>   /var/log/oracle   
                  echo   "Done."   
                  echo   -n   "Restarting   Oracle   Listeners:   "   
                  su   -   oracle   -c   "lsnrctl   stop"   >>   /var/log/oracle   
                  su   -   oracle   -c   "lsnrctl   start"   >>   /var/log/oracle   
                  echo   "Done."   
                  echo   ""   
                  echo   "----------------------------------------------------"   >>   /var/log/oracle   
                  date   +"!   %T   %a   %D   :   Finished."   >>   /var/log/oracle   
                  echo   "----------------------------------------------------"   >>   /var/log/oracle   
                  touch   /var/lock/subsys/oracle   
                  ;;   
      *)   
                  echo   "Usage:   oracle   {start|stop|restart}"   
                  exit   1   
esac   
    
    
    
不要吝啬於检查这个文件到底有没有真的正确地启动和停止系统中的数据库。请检查记录档(log   file),看看有没有错误讯息。     
弄妥这脚本文件後,我们要在正确的执行等级目录   (runlevel   directories)   /etc/rc.d/rcX.d   中建立及删除符号连结   (symbolic   links)。     
以下指令确保在执行等级   2,   3  ,  4,  5   下会叫出数据库∶     
    
    
$   ln   -s   ../init.d/oracle   /etc/rc.d/rc2.d/S99oracle   
$   ln   -s   ../init.d/oracle   /etc/rc.d/rc3.d/S99oracle   
$   ln   -s   ../init.d/oracle   /etc/rc.d/rc4.d/S99oracle   
$   ln   -s   ../init.d/oracle   /etc/rc.d/rc5.d/S99oracle   
    
    
要在重新启动时停止数据库,我们需要以下连结∶     
    
$   ln   -s   ../init.d/oracle   /etc/rc.d/rc0.d/K01oracle                 # 停止   
$   ln   -s   ../init.d/oracle   /etc/rc.d/rc1.d/K01oracle                 # 停止  
$   ln   -s   ../init.d/oracle   /etc/rc.d/rc6.d/K01oracle                 # 重新启动

========================
把oracle service添加到服务里
# chkconfig –add /etc/rc.d/init.d/oracle

查看自动启动设置是否成功:
# chkconfig –list oracle
oracle     0:关闭     1:关闭     2:关闭     3:开启     4:开启     5:开启     6:关闭
*从上面可以看出level为345的都已经开启了,配置成功!
===============================

linux下系统开机oracle自启动(方法二)
以root身份登录:
$su - root
1、linux下oracle自带的dbstart和dbshut没反应:   修改Oracle系统配置文件/etc/oratab文件: #vi /etc/oratab
  /etc/oratab 格式为: SID:ORACLE_HOME:AUTO
  把AUTO域设置为Y(大写),我的为:
  oradb:/opt/u01/app/oracle/product/9.2.0.4:Y

只有这样,oracle 自带的dbstart和dbshut才能够发挥作用。
2、修改/etc/rc.d/rc.local配置文件
   在/etc/rc.d/rc.local中加入如下内容: #vi /etc/rc.d/rc.local
   su - oracle -c "/u01/app/oracle/product/9.2.0.4/bin/lsnrctl start" 
   su - oracle -c "/u01/app/oracle/product/9.2.0.4/bin/dbstart start"
3、重新启动
  #reboot
4、连接测试(以oracle身份登录)
  $sqlplus "
[email=sys/oracle@oradb]sys/oracle@oradb[/email]
as sysdba"
  ...
  sql>
5、说明自启动成功了

名称:su
  使用权限:所有使用者
  使用方式:su [-fmp] [-c command] [-s shell] [--help] [--version] [-] [USER [ARG]]
  说明:变更为其他使用者的身份,除 root 外,需要键入该使用者的密码
  参数:
  -f 或 --fast 不必读启动档(如 csh.cshrc 等),仅用于 csh 或 tcsh
  -m -p 或 --preserve-environment 执行 su 时不改变环境变数
  -c command 或 --command=command 变更为帐号为 USER 的使用者并执行指令(command)后再变回原来使用者
  -s shell 或 --shell=shell 指定要执行的 shell (bash csh tcsh 等),预设值为 /etc/passwd 内的该使用者(USER) shell
  --help 显示说明文件
  --version 显示版本资讯
  - -l 或 --login 这个参数加了之后,就好像是重新 login 为该使用者一样,大部份环境变数(HOME SHELL USER等等)都是以该使用者(USER)为主,并且工作目录也会改变,如果没有指定 USER ,内定是 root
  USER 欲变更的使用者帐号
  ARG 传入新的 shell 参数
  范例:
  su -c ls root 变更帐号为 root 并在执行 ls 指令后退出变回原使用者。
  su root -f 变更帐号为 root 并传入 -f 参数给新执行的 shell。
  su - clsung 变更帐号为 clsung 并改变工作目录至 clsung 的家目录(home dir)。

Oracle在linux下的开机自启动(详细)转的更多相关文章

  1. Linux下设置开机自启动Tomcat

    方法一: linux 下tomcat开机自启动修改Tomcat/bin/startup.sh 为: export JAVA_HOME=/usr/java/j2sdk1..2_08 export CLA ...

  2. postgresql数据库linux下设置开机自启动

    设置PostgreSQL开机自启动PostgreSQL的开机自启动脚本位于PostgreSQL源码目录的contrib/start-scripts路径下cd /opt/soft_bak/postgre ...

  3. linux下redis开机自启动

    将/usr/local/app/redis-4.0.8/redis.conf文件中daemonize no改为daemonize yes 在/etc目录下新建redis目录:mkdir /etc/re ...

  4. linux下tomcat开机自启动

    tomcat自启动配置: 方法一: vi /etc/rc.local 添加如下一行 /opt/apache-tomcat-7.0.29/bin/startup.sh (脚本绝对路径) 注意:要添加在e ...

  5. Linux下mysql开机自启动

    1,cd /etc/init.d/ 2,chmod +x mysql 3,chkconfig add mysql 4,chkconfig --list             显示服务列表 如果看到m ...

  6. debian linux 下设置开机自启动

    懒得写了,一张图简单明了.其实很简单,一开始没有加上nohup有点问题.现在问题已解决.

  7. Linux下Tomcat开机自动启动

    linux下tomcat开机自动启动有两种方法,一种是简单,一种是复杂而又专业的,使用shell脚本要实现,我们一般推荐shell脚本启动方式.下面我们分别介绍这两种方法. 1.shell脚本启动 众 ...

  8. Linux设置程序开机自启动,系统命令chkconfig及linux /etc/rc.d/目录的详解

     整理了linux下程序开启几种方式,转载相关博客做统一记录 <linux程序设置开机自启动>转载自:https://www.cnblogs.com/flcz/p/7691532.html ...

  9. 在linux下安装配置rabbitMQ详细教程

    在linux下安装配置rabbitMQ详细教程 2017年12月20日 17:34:47 阅读数:7539 安装Erlang 由于RabbitMQ依赖Erlang, 所以需要先安装Erlang. Er ...

随机推荐

  1. C#开源系统大汇总(转)

    一.AOP框架        Encase 是C#编写开发的为.NET平台提供的AOP框架.Encase 独特的提供了把方面(aspects)部署到运行时代码,而其它AOP框架依赖配置文件的方式.这种 ...

  2. 向Array中添加冒泡排序

    冒泡排序思想 通过在无序区的相邻元素的比较和替换,使较小的元素浮到最上面. 冒泡排序实现 Function.prototype.method = function(name, func){ this. ...

  3. mobiscroll 控件的使用(手机端日历控件)

    先上一张图吧: 控件的下载地址:http://www.kuitao8.com/20140604/2615.shtml 文档API地址:http://docs.mobiscroll.com/2-13-2 ...

  4. GCC常用命令行一览表

    GCC常用命令行一览表 这些常用的 gcc/g++ 命令行参数,你都知道么?1. gcc -E source_file.c-E,只执行到预编译.直接输出预编译结果. 2. gcc -S source_ ...

  5. Invalid object name ‘sys.configurations’. (Microsoft SQL Server, Error: 208)

    http://blogs.msdn.com/b/ramaprasanna/archive/2009/09/16/invalid-object-name-sys-configurations-micro ...

  6. Linux - 常用命令行(一)

    今天和大家分享一些最基本常用命令行:也是作为新手最应该了解掌握的 ls 命令:用来显示指定工作目录下内容 dir命令:与ls命令一致 cd  命令:变化工作目录 pwd命令:显示用户当前的工作路径,显 ...

  7. 服务器NPC的ID如何分配的

    服务器ID分配包括NPC,Monster,Pet的ID分配都是调用allocateUID然后自动保存的ID加一,pet说是通过玩家的ID移位获得的,调试一下发现还是调用allocateUID,如果通过 ...

  8. 疯狂java讲义——多态

    父类 f = new 子类(); 引用变量f,在编译时类型是父类,在运行时类型是子类类型.当这个引用变量调用子类重写父类的那个方法的时候,实际执行的是子类中重写后的那个方法.当运行的时候调用该变量的方 ...

  9. C#与C++之间类型的对应{转}

    Windows Data Type   .NET Data Type BOOL, BOOLEAN   Boolean or Int32 BSTR    String BYTE    Byte CHAR ...

  10. iptables使用multiport 添加多个不连续端口 不指定

    iptables使用multiport 添加多个不连续端口   碟舞飞扬 , 01:26 , Linux技术 , 评论(0) , 引用(0) , 阅读(12214) , Via 本站原创 大 | 中  ...