Linux下自动检测Tomcat宕机,并自动重启[通俗易懂]

Linux下自动检测Tomcat宕机,并自动重启[通俗易懂]Linux下自动检测Tomcat是否宕机,并自动重启公司服务器tomcat经常自动挂掉,具体原因无法找到。所以做了这次调整。让Linux自动检测tomcat是否宕机1.新建一个名字为XX.sh的文件,文件内容如下#!/bin/sh#获取tomcat进程ID/usr/local/tomcat_ds_api#TomcatID=$(ps-ef|greptomcat|grep-…

大家好,又见面了,我是你们的朋友全栈君。

Linux下自动检测Tomcat是否宕机,并自动重启

公司服务器tomcat经常自动挂掉,具体原因无法找到。所以做了这次调整。让Linux自动检测tomcat是否宕机

1. 新建一个名字为XX.sh的文件,文件内容如下

#!/bin/sh
# 获取tomcat进程ID  /usr/local/tomcat_ds_api
#TomcatID=$(ps -ef |grep tomcat |grep -w 'ps -ef |grep tomcat8.5'|grep -v 'grep'|awk '{print $2}')  
# tomcat启动程序(这里注意tomcat实际安装的路径)  
. /etc/profile #此行必不可少,若少了,tomcat无法自动重启
StartTomcat=/root/apache-tomcat-8.5.40/bin/startup.sh #tomcat绝对路径的启动文件地址
StopTomcat=/root/apache-tomcat-8.5.40/bin/shutdown.sh  #tomcat绝对路径的关闭文件地址
# 定义要监控的页面地址  
WebUrl=“你代码中的某个映射地址,我填的是登录地址”
# 日志输出 
TomcatMonitorLog=/tmp/TomcatMonitor.log  
JAVA_HOME=/usr/local/software/jdk1.8.0_131#下面两行可以不要
JRE_HOME=/usr/local/software/jdk1.8.0_131/jre
tomcat_path='/root/apache-tomcat-8.5.40' #tomcat 完整路径

#获取 tomcat_path 所知tomcat 的进程ID
TomcatID=$(ps -ef |grep tomcat |grep -w $tomcat_path|grep -v 'grep'|awk '{print $2}')
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缓存  
		$StopTomcat
		echo "[info] tomcat关闭成功"
        $StartTomcat  
		echo "[info] tomcat重启成功"
    fi  
  else  
    echo "[error]tomcat进程不存在!tomcat开始自动重启..."  
    echo "[info]$StartTomcat,请稍候......"  
    #rm -rf $TomcatCache  
    $StartTomcat  
  fi  
  echo "------------------------------"  
}  
Monitor>>$TomcatMonitorLog

2.将文件复制到linux的某个文件夹下(我是直接放在tomcat的bin目录下的)

此时,这个脚本文件是不可用的

执行: vi filename
输入: :set ff=unix
			:wq
			回车保存

3.执行该文件

./**.sh
到这里脚本文件就写完了,童鞋们可以去查看日志了。
这里是我们手动启动的,接下来,我们就要去配置一个自动定时任务啦

4.安装crontab

yum install vixie-cron

安装完成。查看一下常用命令。

/sbin/service crond start //启动服务
/sbin/service crond stop //关闭服务
/sbin/service crond restart //重启服务
/sbin/service crond reload //重新载入配置
查看crontab服务状态:service crond status
手动启动crontab服务:service crond start
查看crontab服务是否已设置为开机启动,执行命令:ntsysv
在CentOS系统中加入开机自动启动:chkconfig --level 35 crond on

5.添加定时任务

 crontab  -e --编辑服务文件,添加定时任务
 */1 * * * * 文件所在位置/**.sh
 :wq 保存

启动crontab,这样就完成了。
脚本文件的日志地址在:/tmp 下,可以自行查看

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/163639.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 通过Vagrant搭建PHP环境(一) Vagrant box添加配置「建议收藏」

    通过Vagrant搭建PHP环境(一) Vagrant box添加配置

    2022年2月8日
    40
  • 启用shift后门的方法_shift按五次怎么取消

    启用shift后门的方法_shift按五次怎么取消一、什么是shift后门?shift后门是黑客希望以后方便进入服务器而在没有密码的情况下为进入服务器系统而设置的一个后门。其操作就是在不知道管理员密码的情况下,连续按5次shift键来启动粘滞键,已进入服务器的系统程序管理器。二、shift后门的制作?其制作有很多种,下面介绍一种常用的,可以明白其原理自己扩展:在cmd窗口,敲打命令如下:copyc:\windows\ex

    2026年1月19日
    5
  • 三种非对称加密算法总结

    三种非对称加密算法总结1、DH非对称算法的基石仅能用于密钥分配,不能用于加解密数据,一般加密数据用AES密钥长度:512~1024中的64的整数倍双方各有自己的密钥对2、RSA最经典的非对称加密算法也可认为是使用最多的非对称加密算法能用于密钥分配,也能用于加解密数据(“私钥加密,公钥解密”和“公钥加密,私钥解密”)密钥长度:512~65536(64的整数倍)只有发送方有一个密钥对…

    2025年8月4日
    1
  • 3串12v锂电池充电电压_升压芯片为什么接电池就烧

    3串12v锂电池充电电压_升压芯片为什么接电池就烧两节串联升压充电芯片,带NTC

    2022年10月6日
    3
  • 电阻参数_关于电阻的相关参数

    实际应用时,通常采用平均电阻温度系数,定义式:TCR(平均)=(R2-R1)/R1(T2-T1)有负温度系数、正温度系数及在某一特定温度下电阻只会发生突变的临界温度系数。紫铜的电阻温度系数为1/234.5℃。不同类型电阻温度稳定性从优到次,依次为:金属箔、线绕、金属膜、金属氧化膜、碳膜、有机实芯。1。镀金并不是为了减小电阻,而是因为金的化学性质非常稳定,不容易氧化,接头上镀金是为了防止接触不良(不…

    2022年4月8日
    51
  • java 分布式计算框架_java分布式系统框架的分类「建议收藏」

    java 分布式计算框架_java分布式系统框架的分类「建议收藏」鲁班学院java架构师成长路线随着电商行业的崛起,越来越多的人为了省事更习惯网购,今天我们就来熟悉Java分布式系统中的Dubbo,Dubbo就是来解决Java分布式系统中间的子系统之间相互调用相互协作的一个框架。在Dubbo之前就有一个Java分布式系统框架RPC(远程过程调用),多个子系统之间需要实现相互调用必须要借助网络来表达调用的语义和传达调用的数据,RPC采用客户机/服务器模式。请求程序…

    2022年5月31日
    58

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号