写一个脚本,判断本机的80端口(假设服务为httpd)是否开启着,若是开启着就什么都不作,若是发现端口不存在,那么重启一下httpd服务,并发邮件通知你本身。脚本写好后,每分钟执行一次,也能够写一个死循环的脚本,30S检查一次。python
首先,咱们要区分要求,这里的要求是检测80端口是否在监听,而不是检测httpd服务是否运行,虽然二者有必定的联系,但并非对等的关系。检测端口状态用 netstat -lntp 命令。若是要求检测远程主机的端口状态,则用一下的命令:shell
nmap -p 80 host_remote_ip ## 替换成远程主机的ip就能够了 例如: [root@cenvm72 ~]# nmap -p 80 192.168.188.107 Starting Nmap 6.40 ( http://nmap.org ) at 2018-05-03 11:48 CST Nmap scan report for cenvm71 (192.168.188.107) Host is up (0.00021s latency). PORT STATE SERVICE 80/tcp closed http MAC Address: 00:0C:29:E4:4D:1F (VMware) Nmap done: 1 IP address (1 host up) scanned in 0.14 seconds
[root@cenvm71 work]# cat check_80.sh #!/bin/bash ma="999@qq.com" if netstat -lntp | grep -q ':80 ' then exit 0 fi /usr/local/apache2.4/bin/apachectl restart >/dev/null 2> /dev/null python /usr/local/sbin/work/mail.py $ma "port_80" "prot 80 down" n=`pgrep -l httpd | wc -l` echo $n if [ $n -eq 0 ];then /usr/local/apache2.4/bin/apachectl start 2> /tmp/http.error fi if [ -s /tmp/http.error ] then python /usr/local/sbin/work/mail.py $ma "apache_restart_wrong" "`cat /tmp/http.error`" fi
脚本分析:apache
if 条件的判断能够是一条命令,当命令执行成功条件成立。例如:bash
[root@cenvm71 work]# ls /etc/passwd /etc/passwd [root@cenvm71 work]# ls /etc/okama ls: cannot access /etc/okama: No such file or directory
第一条命令没有出错,第二条命令出错了。若是将他们做为if 的判断条件,效果以下:并发
# if ls /etc/passwd >/dev/null 2>/dev/null ; then echo ok;fi ok # if ls /etc/okma >/dev/null 2>/dev/null ; then echo ok;else echo error; fi error
">/dev/null 2>/dev/null"这个是为了让判断安静进行,将多余的信息重定向,而后,咱们的if 命令只判断返回的状态码。tcp
第二点要注意的是,netstat -lnpt | grep -q ':80 ',是用来判断系统的80端口是否在监听,并且在':80 '最后还有一个空格,这个也是为了匹配准确。由于有可能会匹配到8080端口。ide
grep -q 仅仅进行匹配,不会将结果打印出来,用在 if 判断,效果正好,不用加 ">/dev/null 2>/dev/null";rest
按照要求,若是80端口没有启动,咱们就要启动httpd服务。启动服务以后,咱们还应该检测一下httpd服务是否已经真的启动成功了。方法很简单,就是检测一下httpd进程是否存在。code
pgrep -l httpd 命令,除了会列出httpd 的pid外,还会将进程名称一块儿列出来blog
这道习题并不困难,可是有一些能够琢磨的地方,让你们不断精进。例如if 条件的灵活运用,pgrep的运用,还有邮件脚本的结合运用等等。