oracle与weblogic自动启动与停止 提交时间: Mar 3, 2004 8:42:29 PM 最近做开发时,发觉每次重新启动服务器时oracle数据库若没有关闭,则必须先关闭后在重新启动redhat advance server,oracle才能够正常运行。感觉这样麻烦,想到能否使数据库与web服务器与操作系统一同关闭与启动。在网上查找了一下相关资料,只找到一篇“Oracle Database HOWTO 自动启动及停止.htm”但是没有找到有关weblogic自动启动与停止的文章。经过摸索,我最初的想法实现了,因此想把它写出来,与大家交流。服务器环境:RedHat Advance Server2.1Oracle 9.2.2 for LinuxWeblogic7.0 for Linux一、 oracle自动启动与停止1、 修改Oracle系统配置文件/etc/oratab/etc/oratab 格式为: SID:ORACLE_HOME:AUTO把AUTO域设置为Y(大写),只有这样,oracle 自带的dbstart和dbshut才能够发挥作用。我的为:ora9i:/home/oracle/ora/products/9.2.0:Y2、 编写服务脚本:如下#!/bin/bash##################FUNCTION############### AutoStart Oracle and listener# AutoStop Oracle and listener######################################## Created by ZhouYS 2003-11-26#case "$1" instart)echo "Starting Oracle Databases ... " echo "-------------------------------------------------" >> /var/log/oracledate +" %T %a %D : Starting Oracle Databasee as part of system up." >> /var/log/oracleecho "-------------------------------------------------" >> /var/log/oraclesu - oracle -c "dbstart" >> /var/log/oracleecho "Done."echo "Starting Oracle Listeners ... " echo "-------------------------------------------------" >> /var/log/oracledate +" %T %a %D : Starting Oracle Listeners as part of system up." >> /var/log/oracleecho "-------------------------------------------------" >> /var/log/oraclesu - oracle -c "lsnrctl start" >> /var/log/oracleecho "Done."echo ""echo "-------------------------------------------------" >> /var/log/oracledate +" %T %a %D : Finished." >> /var/log/oracleecho "-------------------------------------------------" >> /var/log/oracletouch /var/lock/subsys/oracle;;stop)echo "Stoping Oracle Listeners ... " echo "-------------------------------------------------" >> /var/log/oracledate +" %T %a %D : Stoping Oracle Listener as part of system down." >> /var/log/oracleecho "-------------------------------------------------" >> /var/log/oraclesu - oracle -c "lsnrctl stop" >> /var/log/oracleecho "Done."rm -f /var/lock/subsys/oracleecho "Stoping Oracle Databases ... "echo "-------------------------------------------------" >> /var/log/oracledate +" %T %a %D : Stoping Oracle Databases as part of system down." >> /var/log/oracleecho "-------------------------------------------------" >> /var/log/oraclesu - oracle -c "dbshut" >>/var/log/oracleecho "Done."echo ""echo "-------------------------------------------------" >> /var/log/oracledate +" %T %a %D : Finished." >> /var/log/oracleecho "-------------------------------------------------" >> /var/log/oracle;;restart)$0 stop$0 start;;*)echo "Usage: oracle {start|stop|restart}" exit 1esac将脚本命名为oracle,保存在/etc/rc.d/init.d下改变文件属性:chmod 755 oracle注意:在windows下编辑此文件时有DOS格式字符导致在linux下不能够正常运行,建议用gedit 或用 vi编辑3、建立服务连接:系统启动时启动数据库,我们需要以下连结∶--------------------------------------------------------------------------------$ 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/rc5.d/S99oracle #rc4.d unused--------------------------------------------------------------------------------要在重新启动时停止数据库,我们需要以下连结∶ --------------------------------------------------------------------------------$ ln -s ../init.d/oracle /etc/rc.d/rc0.d/K01oracle # 停止$ ln -s ../init.d/oracle /etc/rc.d/rc6.d/K01oracle # 重新启动二、weblogic自动启动与停止假设weblogic安装在/home/weblogic/bea下。1、 编写服务脚本:如下#!/bin/bash##################FUNCTION############### AutoStart Weblogic# AutoStop Weblogic ######################################## Created by ZhouYS 2003-11-26# Wellhope Information Technology Co.,Ltd# PUJIANG Science Park(浦江科学园) #shutdownweblogic(){cd /# make temp work dir ,you can create it in /tmpmkdir -p /home/weblogic/zhouys#cd /home/weblogic/zhouys#find weblogic main processps -aux | grep /home/weblogic >tmp01#awk '{print $2}' tmp01 | sort > tmp02#produce kill-main-process scriptecho "kill -9 " `sed -n '1p' tmp02` > tmp03#chmod 755 tmp03# kill weblogic./tmp03cd /home/weblogic/sleep 3rm -rfv zhouys}case "$1" instart)echo "Starting Weblogic ... " echo "-------------------------------------------------" >> /var/log/weblogicdate +" %T %a %D : Starting Weblogic as part of system up." >> /var/log/weblogicecho "-------------------------------------------------" >> /var/log/weblogic cd /home/weblogic/bea/user_projects/mydomain/ >> /dev/null. startWebLogic.sh & >> /var/log/weblogicecho "Done." echo ""echo "-------------------------------------------------" >> /var/log/weblogicdate +" %T %a %D : Finished." >> /var/log/weblogicecho "-------------------------------------------------" >> /var/log/weblogictouch /var/lock/subsys/weblogic;;stop)echo "Stopping Weblogic ... " echo "-------------------------------------------------" >> /var/log/weblogicdate +" %T %a %D : Stopping Weblogic as part of system down." >> /var/log/weblogicecho "-------------------------------------------------" >> /var/log/weblogic shutdownweblogic echo "Done."echo ""echo "-------------------------------------------------" >> /var/log/weblogicdate +" %T %a %D : Finished." >> /var/log/weblogicecho "-------------------------------------------------" >> /var/log/weblogic;;restart)$0 stop#sleep 2 sec to stop all weblogic-processsleep 2$0 start;;*)echo "Usage: $0 {start|stop|restart}" exit 1esac将脚本命名为weblogic,保存在/etc/rc.d/init.d下改变文件属性:chmod 755 weblogic注意:在windows下编辑此文件时有DOS格式字符导致在linux下不能够正常运行,建议用gedit 或用 vi编辑, shutdownweblogic函数中没有加入错误控制,各位可以自己完善。2、 建立服务连接:要在重新启动时停止weblogic,我们需要以下连结∶ [root@js-oracle init.d]# ln -s ../init.d/weblogic /etc/rc.d/rc0.d/K01weblogic[root@js-oracle init.d]# ln -s ../init.d/weblogic /etc/rc.d/rc6.d/K01weblogic系统启动时启动weblogic,我们需要以下连结∶[root@js-oracle init.d]# ln -s ../init.d/weblogic /etc/rc.d/rc2.d/S99weblogic[root@js-oracle init.d]# ln -s ../init.d/weblogic /etc/rc.d/rc3.d/S99weblogic[root@js-oracle init.d]# ln -s ../init.d/weblogic /etc/rc.d/rc5.d/S99weblogic以上在RedHat Advance Server2.1版上配置 level 4 保留unused三、 解释:linux启动时:图形界面 :自动调用/etc/rc.d/rc5.d下的符号连接名称以S开头(意为:start/启动)的脚本文件所指的服务,并自动传递命令行参数 start。Linux关闭时:图形界面 :自动调用/etc/rc.d/rc5.d下的符号连接名称以K开头(意为:kill/关闭)的文件所指的服务,并自动传递命令行参数 stop。其它运行级别与此类似(具体可以参照/etc/rc.d/rc脚本)