Tomcat宕机检测以及宕机自启方法

一. 首先在本地创建一个monitorTomcat .sh的脚本文件,写下以下脚本

#!/bin/sh

# 获取tomcat进程ID  /usr/local/tomcat

TomcatID=$(ps -ef |grep tomcat |grep -w 'tomcat'|grep -v 'grep'|awk '{print $2}')  

# tomcat启动程序(这里注意tomcat实际安装的路径)  

StartTomcat=/home/boss_indb/apache-tomcat-8.0.51/bin/startup.sh

# 定义要监控的页面地址  

WebUrl=http://localhost:8081/login

# 日志输出

TomcatMonitorLog=/home/boss_indb/apache-tomcat-8.0.51/logs/TomcatMonitor.log

Monitor()

{  

  echo "[info]开始监控tomcat...[$(date +'%F %H:%M:%S')]"  

  if [[ $TomcatID ]];then # 这里判断TOMCAT进程是否存在  

    echo "[info]当前tomcat进程ID为:$TomcatID,继续检测页面..."  

    # 检测是否启动成功(成功的话页面会返回状态"200")  

    TomcatServiceCode=$(curl -I -m 10 -o /dev/null -s -w %{http_code} $WebUrl)  

    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

二. 上传到centOS下面,执行以下命令

chmod a+x monitor.sh

./monitor.sh

如果出现以下错误,表名当前这个脚本的属性为doc  而不是 unix,所以要改变这个文件的属性

bin/sh^M: bad interpreter: No such file or directory

解决方法:修改.sh文件格式

    (1)使用vi工具

      vi test.sh

    (2)利用如下命令查看文件格式 

     :set ff 或 :set fileformat 

     可以看到如下信息 

     fileformat=dos 或 fileformat=unix 

     (3) 利用如下命令修改文件格式 

     :set ff=unix 或 :set fileformat=unix 

     :wq (存盘退出)

首次运行monitor文件的时候,如果tomcat没有启动,他会将其启动

三.使用cron定时任务定时执行这个脚本,这样就可以达到实时监控的目的

crontab -e 查看并编辑 定时任务

写入以下语句并 wq 保存

*/1 * * * * /home/boss_indb/software/monitorTomcat.sh

crontab -l 查看当前任务

cron 的相关命令看另一边笔记

四. 在Tomcat宕机了,monitorTomcat.sh脚本去调用bin/startup.sh 命令的时候,出现以下的错误

[info]开始监控tomcat...[2018-10-31 11:23:01]

[error]tomcat进程不存在!tomcat开始自动重启...

[info]/home/boss_indb/apache-tomcat-8.0.51/bin/startup.sh,请稍候......

Neither the JAVA_HOME nor the JRE_HOME environment variable is defined

At least one of these environment variable is needed to run this program

解决办法 : 在tomcat、bin目录下的 setclasspath.sh 文件头部加上以下两个参数(目的就是指定其JDK环境)

export JAVA_HOME=/home/boss_indb/software/jdk1.8.0_152

export JRE_HOME=${JAVA_HOME}/jre

现在手动停掉tomcat,他一会就会自启动了

猜你喜欢

转载自blog.csdn.net/DaySurprise/article/details/88657142