博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
linux 进程监控和自动重启的简单实现
阅读量:6250 次
发布时间:2019-06-22

本文共 1189 字,大约阅读时间需要 3 分钟。

目的:linux 下服务器程序会因为各种原因dump掉,就会影响用户使用,这里提供一个简单的进程监控和重启功能。

实现原理:由定时任务crontab调用脚本,脚本用ps检查进程是否存在,如果不存在则重启并写入日志。

1、crontab修改

# crontab -e*/5 * * * * /mnt/bindmonitor.sh

2、/mnt/bindmonitor.sh 的实现

#! /bin/shhost_dir=`echo ~`                                       # 当前用户根目录proc_name="/home/wkubuntu/named/sbin/named"                             # 进程名file_name="/mnt/bindmonitor.log"                         # 日志文件pid=0proc_num()                                              # 计算进程数{    num=`ps -ef | grep $proc_name | grep -v grep | wc -l`    return $num}proc_id()                                               # 进程号{    pid=`ps -ef | grep $proc_name | grep -v grep | awk '{print $2}'`}proc_numnumber=$?if [ $number -eq 0 ]                                    # 判断进程是否存在then     /home/wkubuntu/named/sbin/named  -c /home/wkubuntu/named/etc/named.conf -n 1 &                                                        # 重启进程的命令,请相应修改    proc_id                                         # 获取新进程号    echo ${pid}, `date` >> $file_name      # 将新进程号和重启时间记录fi

 

3、删除进程测试

a、#killall -15 named

b、5分钟后,cat /mnt/bindmonitor.log看看有无最新的记录,进程号与# ps -ef |grep named 进程号对应。

转载于:https://www.cnblogs.com/fatt/p/4974756.html

你可能感兴趣的文章
ThinkPHP5分页样式设置
查看>>
基于canvas的原生JS时钟效果
查看>>
PL/SQL查看表结构
查看>>
I2C通信时序图解析
查看>>
JSON的学习理解
查看>>
Jenkins+MSbuild+SVN实现dotnet持续集成 快速搭建持续集成环境
查看>>
经典SQL语句大全
查看>>
Android Service
查看>>
病人排序
查看>>
git-修改远程的URL以及强制覆盖本地文件
查看>>
升级fedora 18到fedora 19
查看>>
为什么getline()后要两次回车????(将输入的字符串按单词倒序输出)
查看>>
Dictionary和数组查找效率对比
查看>>
alias命令详情
查看>>
iOS - UITouch
查看>>
学习C++语言的50条忠告
查看>>
mysql的innodb中事务日志ib_logfile
查看>>
大数乘法?
查看>>
C语言博客作业03--函数
查看>>
96. Unique Binary Search Trees(I 和 II)
查看>>