1、前言

在linux运维中,我们经常希望自己运行的脚本能够打印相应的日志,以便出现问题方便排查,shell脚本最简单的打印日志就是把代码运行的结果不断的写入一个文件中去,通过重定向(>>)实现。同时我们也希望能够监控某些进程是否正常运行,如果服务停止,能够自动重启服务。下面以监控tomcat服务为例,供参考。

2、代码实现

#!/bin/sh
while true
do
    count=`ps -ef|grep flask|grep -v grep`
    if [ "$?" != "0" ]
    then
        echo "$(date "+%Y-%m-%d %H:%M:%S") > no tomcat run it" >> /home/a/run_log
        bash /home/a/tomcat/bin/startup.sh
        echo "$(date "+%Y-%m-%d %H:%M:%S") > tomcat restart" >> /home/a/run_log
    else
        echo " $(date "+%Y-%m-%d %H:%M:%S") > tomcat is running..." >> /home/a/run_log
    fi
    sleep 60
done

程序每隔5s就去检测tomcat服务是否存在,存在就打印相应的日志,如果不存在,就把服务重启并提示服务重启。

运行结果如下:

linux 监控进程是否存在并重启进程、打印进程日志_Linux