LINUX定时检查程序运行状态

当初偶那么一不小心,不知怎么给PHP配了个和MySQL版本不匹配的so文件,于是我的数据库就经常因为某些兼容问题挂吖挂吖挂吖。。。动不动MySQL服务就会挂掉,但我又不知道该怎么搞出正确的库,所以只好搞这么一个时刻检查服务是否正确运行的办法来折中一下…

要让检查脚本自动定时执行,我们需要cron,linux里应该都自带了。然后我们需要一个检查脚本,来检查程序是否正在执行,如果不在执行,则启动它。

这里我已经写好了一个

#!/bin/sh
c=`ps -ef | grep 'mysql' |grep -v grep |wc -l`
if [ $c -eq 0 ]
then
    echo "MySQL is not running,starting it."
    echo `service mysql start`
    echo ""
else
    echo "MySQL running!"
fi
 
c=`ps -ef | grep 'apache2' |grep -v grep |wc -l`
if [ $c -eq 0 ]
then
    echo "Apache2 is not running,starting it."
    echo `service apache2 start`
    echo ""
else
    echo "Apache2 running!"
fi
 
c=`ps -ef | grep 'sshd' |grep -v grep |wc -l`
if [ $c -eq 0 ]
then
    echo "SSH is not running,starting it."
    echo `service sshd start`
    echo ""
else
    echo "SSH running!"
fi
 
echo "Service checked done!"

这是一个检查apache2,mysql和ssh三个重要服务的脚本,当发现程序不在运行,脚本就会启动服务。

然后我们要定时来执行这个检查脚本,以前我一直以为cron是个很难用的东西,网上的教程里全都是星星******。。。今天才发现其实用法也很简单(不需要很高级的定时任务的情况下)。
星星都是通配符,匹配任何条件。
我们执行crontab -u 用户名 -e来编辑用户的定时任务,一般来说为了保证任务有权限运行我们都用root用户。如下

crontab -u root -e

接着就会打开vi编辑器,编辑器会打开一个文档,那就是root用户的定时任务文件,要定什么时就直接写在里面保存即可,cron会自动检查并执行到期的任务。

编辑器出现后我们要插个新行并写上我们的任务,任务格式是这样

分钟 小时 一个月里第几天 月份 一周里第几天 要执行的命令

前面的时间部分的值用*代替表示任意此单位的时间都会执行,还有种写法,就是每过多少个单位这样的时间执行一次,如下

*/1 * * * * echo 'miao'

这表示每1分钟执行一次,同理如果第一个位置是*/2的话就是每两分钟执行一次。

现在我们要每一分钟检查一次我们的服务是不是都在正常的运行,所以就写上这么一个任务

*/1 * * * * sh 检查脚本的路径



然后按esc键再:wq保存即可,定时任务就会定时执行了。祖国再也不用担心我的博客老是“数据库连接错误”了。

转载于:https://my.oschina.net/boltwu/blog/466296

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值