linux shell脚本 自动重启挂掉的jar包

简述

服务器最近经常出现jar运行一段时间后自动停止,可能原因是服务器资源不足,例如内存不够用;

shell脚本制作

文件名称:monitor.sh

完整版:

#!/bin/bash
# “#!” 是一个约定的标记,它告诉系统这个脚本需要什么解释器来执行

# 变量
jarName=test.jar

jarUrl=/data/solitasu

webUrl=https://www.baidu.com/

# grep -v grep: 在文档中过滤掉包含有grep字符的行
# awk '{print $2}': 按空格截取第二个
pid=`ps -ef|grep $jarName |grep -v grep| awk '{print $2}'`
# wc -l: jar包进程的数量
num=`ps -ef|grep $jarName |grep -v grep| awk '{print $2}'| wc -l`

MonitorFunction(){
    # 输出文本
    echo "[info]进入监控脚本"`date +'%Y-%m-%d %H:%M:%S'`
    # -eq: 等于
    if [[ $num -eq 0 ]]; then
        echo "[error]进程不存在,重启"`date +'%Y-%m-%d %H:%M:%S'`
		# >> /dev/null : jar包生成日志不打印到此脚本日志中
        java -jar $jarUrl/$jarName >> /dev/null &
    else
        # 获取页面访问状态
        # -m 10: 最多查询10s  --connect-timeout 10:10秒连接超时  -o /dev/null: 屏蔽原有输出信息  -s: silent  -w %{http_code}: 控制额外输出
        code=`curl -s -o /dev/null -m 10 --connect-timeout 10 $webUrl -w %{http_code}`
        # -ne: 不等于
        if [[ $code -ne 200 ]]; then
            echo "[error]页面访问失败,code=$code,重启"`date +'%Y-%m-%d %H:%M:%S'`
            kill -9 $pid
            java -jar $jarUrl/$jarName >> /dev/null & 
        else
            echo "[info]页面访问成功,code=$code,time="`date +'%Y-%m-%d %H:%M:%S'`
        fi
    fi
}
MonitorFunction

简化版

#!/bin/bash
# “#!” 是一个约定的标记,它告诉系统这个脚本需要什么解释器来执行

# 变量
jarName=spsmartmanger-1.0.jar
jarUrl=/www/app/java
# grep -v grep: 在文档中过滤掉包含有grep字符的行
# awk '{print $2}': 按空格截取第二个
pid=`ps -ef|grep $jarName |grep -v grep| awk '{print $2}'`
# wc -l: jar包进程的数量
num=`ps -ef|grep $jarName |grep -v grep| awk '{print $2}'| wc -l`

MonitorFunction(){
    # 输出文本
    echo "[info]进入监控脚本"`date +'%Y-%m-%d %H:%M:%S'`
    # -eq: 等于
    if [[ $num -eq 0 ]]; then
        echo "[error]进程不存在,重启"`date +'%Y-%m-%d %H:%M:%S'`
			# >> /dev/null : jar包生成日志不打印到此脚本日志中
        nuhop java -jar $jarUrl/$jarName &
    fi
}
MonitorFunction

将monitor.sh脚本设为可执行

chmod a+x monitor.sh

定时执行脚本

进入编辑文件

# 查看和设置定时任务
crontab -e

增加定时任务

# 每一分钟执行一次并将日志打印在固定目录中,若文件不存在会自动创建
*/1 * * * * bash /www/app/java/monitor.sh >> /www/app/java/monitor.log
上一篇:Linux文件查找命令find与三剑客之grep


下一篇:linux中find命令、正则表达式、三剑客之grep基本使用