Shell脚本监控Linux某个后台进程,当进程死掉后重新启动服务,以httpd为例

时间:2019-10-23
本文章向大家介绍Shell脚本监控Linux某个后台进程,当进程死掉后重新启动服务,以httpd为例,主要包括Shell脚本监控Linux某个后台进程,当进程死掉后重新启动服务,以httpd为例使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。

Shell脚本如下:

vim monitor.sh

#!/bin/bash

while true   # 无限循环
flag=`ps -aux |grep "httpd" |grep -v "grep" |wc -l`
do
        if [[ $flag -eq 0 ]]   # 判断进程数如果等于0,则启动Apache
        then
                `systemctl start httpd`   # 启动Apache
                echo `date` - "Apache restart" >> running.log   # 将重启时间写入自定义的日
志文件
        else
                echo "Apache is running..." >> /dev/null
        fi
        sleep 3s  # 睡眠3秒后进入下次循环
done

对脚本做一些说明:

ps -aux | grep    # 查找进程

参数:-aux 意思是显示所有包含其他使用者的进程

 

ps -aux | grep "process_name"

若只执行这条命令,会导致出现一个 grep 进程,也就是说若只用上面的命令,会永远得到至少一个进程(grep进程),所以还需要用下面的命令,排除 grep 本身这个进程

grep -v "grep"

最后再用 wc -l 命令统计进程数

if 判断如果大于0,则证明进程正在运行

 

sleep命令可以用来将目前动作延迟一段时间

sleep 1      延迟1秒

sleep 1s    延迟1秒

sleep 1m   延迟1分钟

sleep 1h    延迟1小时

sleep 1d    延迟1天

原文地址:https://www.cnblogs.com/opsprobe/p/11725597.html