安装完毕Oracle 11g每次都得手动启动 | 停止数据库(dbstart | dbshut)、监听器(lsnrctl)、控制台(emtcl)。
设置一下,若手动启动数据库的同时监听器没有启动(即启动数据库时自动启动监听器,停止数据库时停止监听器),则需要修改dbstart脚本文件:
1 2 | [oracle@localhost ~]$ cd /u01/app/oracle/product/11 .1.0 /db_1/bin/ [oracle@localhost ~]$ vi dbstart |
找到下面的代码段:
1 2 3 4 5 6 7 8 | # 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:
1 2 3 4 5 6 7 8 9 10 | [oracle@localhost ~]$ 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启动脚本oracle,内容如下:
1 2 | [oracle@localhost bin]$ cd /etc/init .d/ [oracle@localhost init.d]$ vi oracle |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 | #!/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 .1.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 |
赋予脚本可执行权限:
1 | [oracle@localhost init.d]$ chmod 750 /etc/init .d /oracle |
建立链接:
1 2 | [oracle@localhost init.d]$ ln -s /etc/init .d /oracle /etc/rc1 .d /K61oracle [oracle@localhost init.d]$ ln -s /etc/init .d /oracle /etc/rc3 .d /S61oracle |
启用脚本并添加到服务:
1 2 | [oracle@localhost init.d]$ chkconfig --level 345 oracle on [oracle@localhost init.d]$ chkconfig --add oracle |
注意:
这样的脚本一般不会启动实例,如果想让实例也随脚本一起启动的话,就需要修改文件/etc/oratab
如果这个文件不存在,就要运行脚本文件产生它。
1 | [root@localhost init.d] # $ORACLE_HOME/root.sh |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 | # This file is used by ORACLE utilities. It is created by root.sh # and updated by the Database Configuration Assistant when creating # a database. # A colon, ':', is used as the field terminator. A new line terminates # the entry. Lines beginning with a pound sign, '#', are comments. # # Entries are of the form: # $ORACLE_SID:$ORACLE_HOME:<N|Y>: # # The first and second fields are the system identifier and home # directory of the database respectively. The third filed indicates # to the dbstart utility that the database should , "Y", or should not, # "N", be brought up at system boot time. # # Multiple entries with the same $ORACLE_SID are not allowed. # # orcl: /u01/app/oracle/product/11 .1.0 /db_1 :Y |
可以看出,实例orcl是自动启动的(标识为Y),只要在这里配置好,再配合上面的脚本,即可实现自动启动。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 【杭电多校比赛记录】2025“钉耙编程”中国大学生算法设计春季联赛(1)