【shell脚本】监控某个进程&挂掉重启

脚本monitor.sh

#!/bin/sh
file_name="/home/work/restart.log"  #重启脚本的日志,保证可写入,保险一点执行 chmod 777 restart.log
pid=0
proc_num() 
{
    num=`ps -ef | grep 'sh /home/work/run.sh' | grep -v grep | wc -l`  #此处'sh /home/work/run.sh'替代为实际的,尽量准确,避免误kill
    return $num 
}
proc_id()
{  
    pid=`ps -ef | grep 'sh /home/work/run.sh' | grep -v grep | awk '{print $2}'`  #此处'sh /home/work/run.sh'也替代为实际的
} 
proc_num  #执行proc_num(),获取进程数
number=$?  #获取上一函数返回值
if [ $number -eq 0 ]  #如果没有该进程,则重启
then
    sh /home/work/run.sh  #启动程序的命令
    proc_id 
    echo ${pid}, `date` >> $file_name  #把重启的进程号、时间 写入日志
fi

然后,使用crontab定期没2分钟调用一次监控脚本
crontab -e
加入一行
*/2 * * * * sh /home/work/monitor.sh

完成~
转自 http://17coding.top

shell脚本监控和自动重启挂掉的Java服务,通常会涉及以下几个步骤: 1. **检测服务状态**: 使用`ps -ef | grep [service_name]`命令检查Java进程是否存在,如果进程ID(PID)为空或者返回非零值表示服务已停止。 2. **设置检查间隔**: 使用`sleep`命令定义一段时间,比如每5秒或10秒检查一次,确保有足够的频率来及时发现服务异常。 3. **监控和判断**: 写一个循环,检查服务状态。如果服务未运行(例如进程不存在),则继续执行下一步。 4. **重启服务**: 如果服务挂掉,使用`nohup java -jar your_service.jar &> /dev/null &`这样的命令重启服务,并将日志重定向到/dev/null以避免干扰监控信息。 5. **记录日志**: 可以考虑记录下服务重启的原因和时间,以便于后期分析。 6. **异常处理**: 加入错误处理机制,比如检查重启操作是否成功,以及防止无限次重启导致的资源耗尽。 7. **循环监控**: 将整个过程封装在一个while循环中,直到用户手动结束或者满足特定的退出条件。 以下是一个简单的示例脚本结构: ```bash #!/bin/bash SERVICE_NAME=your_service LOG_FILE=restart_log.txt while true; do if ! ps aux | grep -v "grep" | grep "$SERVICE_NAME"; then echo "Java service $SERVICE_NAME is down. Restarting..." nohup java -jar your_service.jar &> /dev/null & echo "$(date) - Service restarted." >> $LOG_FILE sleep 5 else echo "Service running." sleep 5 fi done #
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值