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的路径:
setclasspath.sh

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值