最近正在学习shell脚本,突然想到如何使用一个shell脚本监控tomcat,参考 linux浪子 的博客 http://kkkkkk.blog.51cto.com/468162/1190396。
自己亲自重新写了一份shell脚本,实现自动监控重启tomcat。
系统环境:CentOS 6.7 x86_64
jdk版本:1.7.0_80
tomcat版本:7.0.70
- # ---------------------------------------------------------------------- #
- # shell自动监控重启tomcat脚本
- # 思路是这样的:先检测tomcat进程是否存在,如果不存在就启动,如果进程存在,检测页面返回码状态,如果是200就是正常,如果不是就重启。
- # 测试OK后把脚本加入到crontab。
- # ---------------------------------------------------------------------- #
- #!/bin/sh
- # 定义环境变量
- PATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/usr/local/jdk1.7.0_80/bin
- export JAVA_HOME=/usr/local/jdk1.7.0_80
- export CLASSPATH=$JAVA_HOME/lib:$JAVA_HOME/lib/tools.jar
- export PATH=$PATH:$JAVA_HOME/bin
- # DEFINE
- # 获取tomcat进程ID
- TomcatID=$(ps -ef |grep tomcat |grep -w 'apache-tomcat-7.0.70'|grep -v 'grep'|awk '{print $2}')
- # tomcat启动程序(这里注意tomcat实际安装的路径)
- StartTomcat=/usr/local/apache-tomcat-7.0.70/bin/startup.sh
- TomcatCache=/usr/local/apache-tomcat-7.0.70/work
- # 定义要监控的页面地址
- WebUrl=http://localhost:8080
- # 日志输出
- GetPageInfo=/usr/local/demo/shell/TomcatMonitor.Info
- TomcatMonitorLog=/usr/local/demo/shell/TomcatMonitor.log
- Monitor () {
- echo "[info] 开始监控tomcat...[$(date +'%F %H:%M:%S')]"
- if [ $TomcatID ];then # 这里判断TOMCAT进程是否存在
- echo "[info] 当前tomcat进程ID为:$TomcatID,继续检测页面..."
- # 检测是否启动成功(成功的话页面会返回状态"200")
- TomcatServiceCode=$(curl -s -o $GetPageInfo -m 10 --connect-timeout 10 $WebUrl -w %{http_code})
- if [ $TomcatServiceCode -eq 200 ];then
- echo "[info] 页面返回码为$TomcatServiceCode,tomcat启动成功,测试页面正常..."
- else
- echo "[error] tomcat页面出错,请注意...状态码为$TomcatServiceCode,错误日志已输出到$GetPageInfo"
- echo "[error] 页面访问出错,开始重启tomcat"
- kill -9 $TomcatID # 杀掉原tomcat进程
- sleep 3
- rm -rf $TomcatCache # 清理tomcat缓存
- $StartTomcat
- fi
- else
- echo "[error]tomcat进程不存在!tomcat开始自动重启..."
- echo "[info]$StartTomcat,请稍候..."
- rm -rf $TomcatCache
- $StartTomcat
- fi
- echo "----------------------------------------------------------------------"
- }
- Monitor >> $TomcatMonitorLog