龙空技术网

Shell脚本实现进程守护(看门狗功能)

软件探索家 1238

前言:

现时看官们对“centos suse”大概比较关切,小伙伴们都想要了解一些“centos suse”的相关资讯。那么小编也在网络上收集了一些有关“centos suse””的相关内容,希望我们能喜欢,朋友们快快来了解一下吧!

在linux平台部署相关应用进程后,可能经常会遇到的一个问题就是因为进程的本身bug或者其他原因进程异常退出, 退出后如果没有完善告警通知机制的话,应用的相关业务可能也就因此而中断了。对此可能还有其他相关的损失。

因此使用shell来实现一款小巧实用的看门狗脚本,配合系统自带的定时任务完成对进程的守护。并记录详细的守护日志。

话不多说,直接上脚本:

使用方法:

支持多个进程一起进行守护,在SCRIPTNAME 后面的括号中放入需要守护的进程或者脚本名称(和本脚本在同一个目录中)WORKDIR 修改成实际的实际的工作目录路径。crontab任务中配置每分钟执行的任务。脚本支持:1. 对自行日志文件大小的管理,2. 支持对被守护进程的状态监控并实施拉起。

#!/bin/bash#Monitor script.WORKDIR="/home/monitor"#此处添加需要守护的应用或者脚本名称,支持多个一起监控。SCRIPTNAME=(gs_monitor.py)LOG_FILE="$WORKDIR/log/mon.log"FLG_FILE="$WORKDIR/log/.flg"SCRIPT_PATH=$WORKDIRcur_datemsg=`echo $(date '+%Y-%m-%d')`##logcreate(){    echo "================================================================================" >> $LOG_FILE    echo "$cur_datemsg" >> $LOG_FILE    echo "$cur_datemsg" > $FLG_FILE    echo "================================================================================" >> $LOG_FILE}if [ -d $WORKDIR/log ]then	echo "logs dir already there." >> /dev/nullelse     mkdir -p $WORKDIR/log	 logcreatefi##if [ -f $LOG_FILE ]then    file_size=`ls -l $LOG_FILE | awk '{print $5}'`else    touch $LOG_FILE	logcreate    file_size=0fiif [ $file_size -ge 10485760 ]#if [ $file_size -ge 104 ]then    mv $LOG_FILE $WORKDIR/log/.mon_named.log.$cur_datemsg	rm $LOG_FILE	logcreatefiOS_Type=`uname`for ins in `seq 0 0`;do##echo ${SCRIPTNAME[$ins]}if [ $OS_Type == "Linux" ]then    PID=`ps -ef | grep -v vi | grep -v tail | grep ${SCRIPTNAME[$ins]} | grep -v grep | awk '{print $2}'`    #echo "[$(date '+%Y-%m-%d %H:%M:%S')]:$OS_Type , Script ${SCRIPTNAME[$ins]} already running pid is $PID" >> $LOG_FILEfiif [ x${PID} == "x" ]then    echo "[$(date '+%Y-%m-%d %H:%M:%S')]: Auto script ${SCRIPTNAME[$ins]} is not running, restart it!" >> $LOG_FILE    case $OS_Type in        "Linux")            $SCRIPT_PATH/${SCRIPTNAME[$ins]} & >/dev/null 2>/dev/null >> $LOG_FILE            ;;        *)            echo "[$(date '+%Y-%m-%d %H:%M:%S')]: OS type $OS_Type is not supported!" >> $LOG_FILE           ;;    esac 	if [ $OS_Type == "Linux" ]thenecho ${SCRIPTNAME[$ins]}    XPID=`ps -ef | grep -v vi | grep -v tail | grep ${SCRIPTNAME[$ins]} | grep -v grep | awk '{print $2}'`fiif [ x${XPID} == "x" ]then    echo "[$(date '+%Y-%m-%d %H:%M:%S')]: Auto script ${SCRIPTNAME[$ins]} cannot be started! Please check!" >> $LOG_FILEelse    echo "[$(date '+%Y-%m-%d %H:%M:%S')]: Auto script ${SCRIPTNAME[$ins]} is running now! The PID is $XPID" >> $LOG_FILEfifidone

该脚本在centos 和 suse linux平台已经平稳运行3年以上,今天拿出来共享给有需要的朋友们进行使用,使用过程中如果有需要的可以私信联系我。大家一起讨论。

标签: #centos suse