[crontab 设置检测Tomcat状态重启]容易遇到的问题

2017-11-17  本文已影响10人  長得太帥忚四種檌

1.定时启动设置

crontab -e
然后设置每分钟执行一次脚本
* * * * * /usr/local/tomcat/bin/monitor.sh

2.monitor脚本内容:

#!/bin/sh
# 获取tomcat进程ID
ServerID=$(ps -ef |grep tomcat |grep -w 'org.apache.catalina.startup.Bootstrap'|grep -v 'grep'|awk '{print $2}') 

# tomcat启动程序(这里注意tomcat实际安装的路径)  
StartTomcat=/app/tomcat/bin/startup.sh

# 定义要监控的页面地址  
WebUrl=http://localhost:8080/BookReaderServer/action/test

# 日志输出 
ServerMonitorLog=/app/tomcat/logs/ServerMonitor.log 

Monitor() 
{  
  echo "[info]开始监控tomcat...[$(date +'%F %H:%M:%S')]"  
  if [[ $ServerID ]];then # 这里判断TOMCAT进程是否存在  
    echo "[info]当前tomcat进程ID为:$ServerID,继续检测页面..."  
    # 检测是否启动成功(成功的话页面会返回状态"200")  
    ServiceCode=$(curl -I -m 10 -o /dev/null -s -w %{http_code} $WebUrl)  
    if [ $ServiceCode -eq 200 ];then  
        echo "[info]页面返回码为$ServiceCode,tomcat启动成功,测试页面正常......"  
    else  
        echo "[error]tomcat页面出错,请注意......状态码为$ServiceCode,错误日志已输出到$ServerMonitorLog"  
        echo "[error]页面访问出错,开始重启tomcat"  
        kill -9 $ServerID  # 杀掉原tomcat进程  
        sleep 3  
        $StartTomcat
    fi  
  else  
    echo "[error]tomcat进程不存在!tomcat开始自动重启..."  
    echo "[info]$StartTomcat,请稍候......"  
    $StartTomcat  
  fi  
  echo "------------------------------"  
}  
Monitor>>$ServerMonitorLog

3.crontab启动的脚本可能会找不到java, 因为环境变量没有,可以在catalina.sh文件中直接指定jdk路径:

export JAVA_HOME=/usr/local/java/jdk1.8.0_144
export JRE_HOME=$JAVA_HOME/jre
上一篇下一篇

猜你喜欢

热点阅读