Tomcat的监控脚本,以及问题记录

  公司使用的是jenkins来管理maven工程的构建,不知道什么原因,环境上的Tomcat隔几天就自己挂掉了,至今比较费解,然后老大要求说是不行就写一个监控Tomcat的脚本,当Tomcat挂掉的时候可以自己拉起来。

  然后开始编写脚本,在这里把自己编写脚本时候的问题记录下来:  

#!/bin/sh

# 获取tomcat进程ID
TomcatID=$(ps -ef |grep tomcat |grep -w '/opt/apache-tomcat-9.0.20/bin'|grep -v 'grep'|awk '{print $2}')

# tomcat启动程序
StartTomcat=/opt/apache-tomcat-9.0.20/bin/startup.sh

#日志输出

PageInfo=/var/log/runlog/tmp/PageInfo.log
TomcatMonitorLog=/var/log/runlog/tmp/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 $PageInfo -m 10 --connect-timeout 10 $http://127.0.0.1:8080 -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
      sh $StartTomcat
  else
    echo "[error]tomcat进程不存在!tomcat开始自动重启..."
    echo "[info]$StartTomcat,请稍候......"
    sh $StartTomcat 
  fi
echo "------------------------------"
}
Monitor>>$TomcatMonitorLog


  在这里要注意:有的环境存在很多的tomcat进程,所以在这里我使用ps -ef |grep tomcat |grep -w '/opt/apache-tomcat-9.0.20/bin'|grep -v 'grep'|awk '{print $2}来获取tomcat相关的进程ID;

  当我把该脚本放在Linux的定时任务中测试的时候发现报找不到JDK或JRE的错;赶紧去/etc/profile文件中查看,发现配置了JDK的环境变量了,为什么还是会报错呢?很令人费解...

  

  后来发现,原来是得在tomcat的bin目录下的setclasspath.sh文件中添加JDK和JRE的路径:

    

 

posted @ 2020-03-31 22:52  MaX好吗  阅读(287)  评论(0编辑  收藏  举报