寫一個腳本,判斷本機的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的運用,還有郵件腳本的結合運用等等。