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

本文介绍在Linux系统下对Tomcat进行监控的方法。先创建monitorTomcat.sh脚本,上传到CentOS执行,若遇文件格式问题可修改。使用cron定时任务实现实时监控。还给出Tomcat宕机重启时因未定义JDK环境变量报错的解决办法,指定JDK环境后可实现自启动。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

【颜色说明:橙色 为 命令   绿色 为 代码 】

一. 首先在本地创建一个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,他一会就会自启动了

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值