shell腳本:監控MySQL服務是否正常

監控MySQL服務是否正常,通常的思路爲:檢查3306端口是否啓動,ps查看mysqld進程是否啓動,命令行登錄mysql執行語句返回結果,php或jsp程序檢測(需要開發人員開發程序)等等;


方法1:監聽3306端口

#!/bin/bash

port=`netstat -nlt|grep 3306|wc -l`

if [ $port -ne 1 ]

then

 /etc/init.d/mysqld start

else

 echo "MySQL is running"

fi


方法2:查看mysqld進程

注意注意:如果使用進程過濾的話,腳本名稱如果裏面包含mysql的話,腳本執行有坑,切記!!!因爲會把腳本也grep了一次,導致結果不準確;


[root@localhost ]# cat check_mysql.sh

#!/bin/bash

#written by mofansheng@2015-10-15

 

process=`ps -ef |grep mysql|grep -v grep |wc -l`

if [ $process -ne 2 ]

then

 /etc/init.d/mysqld start

else

 echo "MySQL is running"

fi

執行結果如下:

[root@localhost ]# sh check_mysql.sh

Starting MySQL SUCCESS! 

改名之後執行爲正常結果:

[root@localhost ]# mv check_mysql.sh check_db.sh

[root@localhost ]# sh check_db.sh

MySQL is running


方法3:雙保險,進程和端口都成功纔算mysql服務正常


#!/bin/bash

 

port=`netstat -nlt|grep 3306|wc -l`

process=`ps -ef |grep mysql|grep -v grep |wc -l`

if [ $port -eq 1 ] && [ $process -eq 2 ]

then

     echo "MySQL is running"

else

    /etc/init.d/mysqld start

fi


4:使用客戶端登錄mysql執行命令,查看返回結果測試服務是否啓動,理論上此方法最可靠。


[root@localhost ]# cat check_db_client.sh

#!/bin/bash


mysql -uroot -p123456 -e "select version();" &>/dev/null

if [ $? -ne 0 ]

then

 /etc/init.d/mysqld start

else

 echo "MySQL is running"

fi

執行結果如下:

[root@localhost ]# sh check_db_client.sh

MySQL is running



本文出自 “模範生的學習博客” 博客,請務必保留此出處http://mofansheng.blog.51cto.com/8792265/1703285

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章