当初偶那么一不小心,不知怎么给PHP配了个和MySQL版本不匹配的so文件,于是我的数据库就经常因为某些兼容问题挂吖挂吖挂吖。。。动不动MySQL服务就会挂掉,但我又不知道该怎么搞出正确的库,所以只好搞这么一个时刻检查服务是否正确运行的办法来折中一下…
要让检查脚本自动定时执行,我们需要
这里我已经写好了一个
#!/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三个重要服务的脚本,当发现程序不在运行,脚本就会启动服务。
然后我们要定时来执行这个检查脚本,以前我一直以为crontab-u用户名-e来编辑用户的定时任务,一般来说为了保证任务有权限运行我们都用root用户。如下
crontab -u root -e
接着就会打开vi编辑器,编辑器会打开一个文档,那就是root用户的定时任务文件,要定什么时就直接写在里面保存即可,cron会自动检查并执行到期的任务。
编辑器出现后我们要插个新行并写上我们的任务,任务格式是这样
分钟 小时 一个月里第几天 月份 一周里第几天 要执行的命令
前面的时间部分的值用*代替表示任意此单位的时间都会执行,还有种写法,就是每过多少个单位这样的时间执行一次,如下
*/1 * * * * echo ‘miao’
这表示每1分钟执行一次,同理如果第一个位置是*/2的话就是每两分钟执行一次。
现在我们要每一分钟检查一次我们的服务是不是都在正常的运行,所以就写上这么一个任务
*/1 * * * * sh 检查脚本的路径
然后按esc键再:wq保存即可,定时任务就会定时执行了。祖国再也不用担心我的博客老是“数据库连接错误”了。