检测Tomcat日志异常自动重启

摘要:
检测Tomcat日志关键字异常。在日常工作中,我们经常遇到Tomcat日志报告的特定错误,导致Linux服务器CPU飙升。此时,我们需要重新启动应用程序以降低它,因此我们需要编写一个shell脚本。当报告特定错误时,按如下方式重新启动应用程序外壳脚本:[root@Mike-VM-Node-10_10_0_188~]#vim/app/scripts/auto restart.sh#!/bin/sh#tomcatdir=(tomcat-

检测Tomcat日志关键字异常

日常工作中经常会遇到Tomcat日志报特定的错误导致 Linux 服务器CPU暴涨,这时候需要重启应用才可以降下来

所以就需要写一个shell脚本,报出特定的错误就重启应用

shell脚本如下:

[root@Mike-VM-Node-10_10_0_188 ~]# vim /app/scripts/auto-restart.sh
#!/bin/sh#
tomcatdir=(
tomcat-9.0.19-app-8080)

sys_log=catalina.`date +%Y-%m-%d`.out
err_log=/app/scripts/err.log
err_time=`date +%Y-%m-%d_%H:%M`
restart_log=/app/scripts/restart-system.log

for ((i=0;i<${#tomcatdir[*]};i++))
  do
    grep -E -i "Connection is not available|java.lang.OutOfMemoryError" /app/${tomcatdir[$i]}/logs/$sys_log >$err_log
    if [ -s $err_log ];then  
         echo ${err_time}_${tomcatdir[$i]}"_内存溢出或者连接池问题自动重启" >>$restart_log
         mv /app/${tomcatdir[$i]}/logs/$sys_log /app/${tomcatdir[$i]}/logs/${err_time}.out
         /etc/init.d/${tomcatdir[$i]} restart
#      else#        echo ${err_time}_${tomcatdir[$i]}"_没有连接池异常" >>$restart_log
    fi
done

需要在/etc/init.d/下创建一个重启脚本

重启脚本如下:

[root@Mike-VM-Node-10_10_0_188 ~]# vim /etc/init.d/tomcat-9.0.19-app-8080
#!/bin/bash
### BEGIN INIT INFO
# Provides:          tomcat
# Required-Start:    $remote_fs $syslog
# Required-Stop:     $remote_fs $syslog
# Default-Start:     2 3 4 5# Default-Stop:      0 1 6# Short-Description: tomcat-server daemon
# Description:       tomcat-server daemon
### END INIT INFO
#
# chkconfig: - 95 15# description: Tomcat start/stop/status script

#Location of JAVA_HOME (bin files)
export JAVA_HOME=/app/jdk8

#Add Java binary files to PATH
export PATH=$JAVA_HOME/bin:$PATH

#CATALINA_HOME is the location of the configuration files of this instance of Tomcat
CATALINA_HOME=/app/tomcat-9.0.19-app-8080
#TOMCAT_USER is the default user of tomcat
TOMCAT_USER=root

#TOMCAT_USAGE is the message ifthis script is called without any options
TOMCAT_USAGE="Usage: $0 {e[00;32mstarte[00m|e[00;31mstope[00m|e[00;32mstatuse[00m|e[00;31mrestarte[00m}"
#SHUTDOWN_WAIT is wait time in seconds forjava proccess to stop
SHUTDOWN_WAIT=10
tomcat_pid() {
  echo `ps -ef | grep ${CATALINA_HOME}/conf | grep -v grep | tr -s " "|cut -d" " -f2`
}

start() {
  pid=$(tomcat_pid)
  if [ -n "$pid" ]; then
    echo -e "e[00;31mTomcat is already running (pid: $pid)e[00m"
  else
    echo -e "e[00;32mStarting tomcate[00m"
    if [ `user_exists $TOMCAT_USER` = "1" ]; then
      su $TOMCAT_USER -c $CATALINA_HOME/bin/startup.sh
    else$CATALINA_HOME/bin/startup.sh
    fistatus
  fireturn 0}

status() {
  pid=$(tomcat_pid)
  if [ -n "$pid" ]; then
    echo -e "e[00;32mTomcat is running with pid: $pide[00m"
  else
    echo -e "e[00;31mTomcat is not runninge[00m"
  fi}

stop() {
  pid=$(tomcat_pid)
  if [ -n "$pid" ]; then
    echo -e "e[00;31mStoping Tomcate[00m"
    $CATALINA_HOME/bin/shutdown.sh
    let kwait=$SHUTDOWN_WAIT
    count=0;
    until [ `ps -p $pid | grep -c $pid` = '0' ] || [ $count -gt $kwait ]
    do
      echo -n -e "e[00;31mwaiting for processes to exite[00m
";
      sleep 1let count=$count+1;
    done

    if [ $count -gt $kwait ]; then
      echo -n -e "e[00;31mkilling processes which didn't stop after $SHUTDOWN_WAIT secondse[00m"
      kill -9$pid
    fi
  else
    echo -e "e[00;31mTomcat is not runninge[00m"
  fi
  return 0}

user_exists() {
  if id -u $1 >/dev/null 2>&1; then
    echo "1"
  else
    echo "0"
  fi}

case $1 instart)
    start
    ;;
  stop)
    stop
    ;;
  restart)
    stop
    start
    ;;
  status)
    status
    ;;
  *)
    echo -e $TOMCAT_USAGE
    ;;
esacexit 0[root@Mike-VM-Node-10_10_0_188 ~]# chmod +x /etc/init.d/tomcat-9.0.19-app-8080

再设置定时任务就大功告成

[root@Mike-VM-Node-10_10_0_188 ~]# crontab -e

*/1 * * * * /bin/sh /app/scripts/auto-restart.sh[root@Mike-VM-Node-10_10_0_188 ~]#

每分钟检测一次有没有报特定的错误,有就重启

本文分享完毕,感谢支持点赞~~

免责声明:文章转载自《检测Tomcat日志异常自动重启》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇我的css释疑-float line-height inline-block vertical-alignlog4net写入到SQL server的基本配置(downmoon)下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

随便看看

HTTP请求报文

不仅报表样式可以传递请求参数,请求url也可以以类似于键值对的方式传递数据...

移动端媒体查询的一些尺寸参考

device-width是设备实际的宽度,不会随着屏幕的旋转而改变,因此并不适合开发响应式网站。比如iphone5s的屏幕分辨率宽为640,由于retina显示策略,当scale设置为1的时候,对应的media中取到的width为320,当scale设置为0.5的时候,width为640,而device-width始终是320。总结1.device-widt...

电脑不识别USB blaster驱动问题

电脑不识别USB blaster,如下图: 解决办法:手动更新...

Linux系统glibc库版本信息查看

有时我们经常需要检查当前系统的glibc版本。您可以按如下方式进行检查:/lib/libc。所以。6有时:/lib/x86-64-linux/libc。因此6.将文件作为命令执行。为什么库可以直接运行?Glibc是gnu发布的libc库,即c运行时。glibc是linux系统中最低级别的api,几乎任何其他运行时都将依赖glibc。Gcc和libc是相互依赖...

内网esxi磁盘空间不足导致虚拟机宕机

因为一些占用太多空间的虚拟机可能无法启动。我不断拍摄快照以保存测试版本。我跳过了同一网段上的一个虚拟机ssh,并一直看着翻译器学习如何释放虚拟磁盘空间。您只能创建一个新的虚拟机来读取原始磁盘目录,并且只能重新构建一个新Linux机器进行测试。然后上传一个测试文件(最大程度地模拟其他虚拟机环境)。首先,你需要关闭机器。厚配置延迟将整个虚拟机目录文件清零,如下所...

利用油猴插件实现全网VIP视频免费看

利用油猴插件实现全网VIP视频免费看第一步:首先打开谷歌应用商店搜索tampermonkey安装这个插件第二步:在百度搜索框搜索油猴可以看到以下页面,点击进入。下载谷歌上网助手解压后,将后缀为crx的文件拖入即可。之后注册一个谷歌上网助手账后登录即可进入谷歌应用商店油猴插件...