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服务是否存在,存在就打印相应的日志,如果不存在,就把服务重启并提示服务重启。
运行结果如下: