LINUX下使用Shell自动监控tomcat并且执行重启操作

 

转自http://my.oschina.net/chinaearl/blog/111830,如有侵权,请通知我,我及时删除。

下面的文件名称为monitor.sh,如果没有执行权限请使用chmod 777 monitor.sh

[plain]  view plain copy
 
  1. #!/bin/sh  
  2.   
  3. # func:自动监控tomcat脚本并且执行重启操作  
  4. # author:danny  
  5. # date:02/20/2013  
  6. # DEFINE  
  7.   
  8. # 获取tomcat进程ID  
  9. TomcatID=$(ps -ef |grep tomcat |grep -w 'dw\/apache-tomcat-7.0.34\/conf'|grep -v 'grep'|awk '{print $2}')  
  10.   
  11. # tomcat启动程序(这里注意tomcat实际安装的路径)  
  12. StartTomcat=/home/dw/apache-tomcat-7.0.34/bin/startup.sh  
  13. #TomcatCache=/usr/apache-tomcat-5.5.23/work  
  14.   
  15. # 定义要监控的页面地址  
  16. WebUrl=http://haoyayi.eyar.com  
  17.   
  18. # 日志输出  
  19. GetPageInfo=/dev/null  
  20. TomcatMonitorLog=/tmp/TomcatMonitor.log  
  21.   
  22. Monitor()  
  23. {  
  24.   echo "[info]开始监控tomcat...[$(date +'%F %H:%M:%S')]"  
  25.   if [[ $TomcatID ]];then # 这里判断TOMCAT进程是否存在  
  26.     echo "[info]当前tomcat进程ID为:$TomcatID,继续检测页面..."  
  27.     # 检测是否启动成功(成功的话页面会返回状态"200")  
  28.     TomcatServiceCode=$(curl -s -o $GetPageInfo -m 10 --connect-timeout 10 $WebUrl -w %{http_code})  
  29.     if [ $TomcatServiceCode -eq 200 ];then  
  30.         echo "[info]页面返回码为$TomcatServiceCode,tomcat启动成功,测试页面正常......"  
  31.     else  
  32.         echo "[error]tomcat页面出错,请注意......状态码为$TomcatServiceCode,错误日志已输出到$GetPageInfo"  
  33.         echo "[error]页面访问出错,开始重启tomcat"  
  34.         #kill -9 $TomcatID  # 杀掉原tomcat进程  
  35.         #sleep 3  
  36.         #rm -rf $TomcatCache # 清理tomcat缓存  
  37.         #$StartTomcat  
  38.     fi  
  39.   else  
  40.     echo "[error]tomcat进程不存在!tomcat开始自动重启..."  
  41.     echo "[info]$StartTomcat,请稍候......"  
  42.     #rm -rf $TomcatCache  
  43.     #$StartTomcat  
  44.   fi  
  45.   echo "------------------------------"  
  46. }  
  47. Monitor>>$TomcatMonitorLog  



下面是的这段代码是监控tomcat是否运行,如果运行,则将其停止.文件名称本人叫做shutdown.sh

[plain]  view plain copy
 
  1. #!/bin/sh  
  2. TomcatID=$(ps -ef |grep hudson-3.01 |grep java | awk ' { print $2 } ')  
  3. echo "tomcat的pid为$TomcatID"  
  4. Monitor(){  
  5.         echo "[info]开始监控tomcat...[$(date +'%F %H:%M:%S')]"  
  6.         if [[ $TomcatID ]]  
  7. # 这里判断TOMCAT进程是否存在  
  8.            then  
  9.                 echo "tomca启动正常"  
  10.                 kill -9 $TomcatID  
  11.                 tempTomcatID=$(ps -ef |grep hudson-3.01 |grep java | awk ' { print $2 } ')  
  12.                 if [[ $tempTomcatID ]]  
  13.                         then  
  14.                         echo "停止失败"  
  15.                 else   
  16.                         echo "成功停止"  
  17.                 fi  
  18.         else  
  19.             echo "tomcat没有启动"  
  20.         fi  
  21. }  
  22.   
  23.   
  24. Monitor  



下面的代码是启动tomca并将其日志显示出来,文件名称本人叫做startup.sh

[plain]  view plain copy
 
  1. cd /home/test/hudson-3.01/bin && ./startup.sh && tail -f ../logs/catalina.out  

你可能感兴趣的:(tomcat)