您的位置:首页 > 大数据 > 人工智能

aix系统中服务进程监控并自启动脚本

2012-10-16 10:18 232 查看
服务器中的一些服务进程可能不稳定,偶尔会自动异常终止,需要一个监控程序脚本来对这个进程进行监控,当发现被监控的服务进程异常终止或不能正常提供服务了,将其启动或重新启动。

基本实现思路是,编写一个监控脚本,然后在系统的crontab中将该脚本配置为定期自动执行(例如可以配置为每5分钟执行一次),监控脚本通过监控服务进程的端口或日志文件的修改时间等来判断服务进程是否已异常终止或不能正常提供服务了,当监控条件成立时,重启被监控的服务进程。

具体方法为:

(1)监控服务进程的端口,当服务进程的端口不通时,自动重启服务进程。这个需要该服务进程始终监听某一特殊端口,并当服务停止或不能正常提供服务时。

脚本样例,监控jboss服务器的8080端口,当该端口不通时,自动重启jboss服务器。

#!/bin/sh

netstat -an|grep -q 8080

if [ $? -ne 1 ]; then exit; fi

cd /home/jboss-3.2.6/bin

echo "Jboss Service restart at" >>WatchDog.log

date >>IntfWatchDog.log

/home/jboss-3.2.6/bin/jboss restart

(2)监控服务进程的日志,比较日志的最后修改时间与系统当前时间,若两时间差超过某一值时,说明服务进程不能正常提供服务了,对服务进程进行重启。这个监控方法使用于服务进程会定期记录日志的情况。

样例脚本,当服务日志最后修改时间与系统时间相差超过5分钟时,自动重启服务进程。

#!/bin/sh

file=/home/log/xxx.log

#t1 is current minute ,t2 is file's last modify minute

t1=`date |awk '{ print $4 }'|cut -d: -f 2`

t2=`ls -l $file|awk '{print$8}'|cut -d: -f2`

#compare the differ minute of the two

diff=`expr $t1 - $t2`

#echo $diff

if [ $diff -eq -55 -o $diff -gt "4" ]; then

echo "service restart at `date`" >>/home/log/Watch.log;

【your service restart command here】

fi;
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: