shell指令碼:監控MySQL服務是否正常

yifanwu發表於2021-09-09


監控MySQL服務是否正常,通常的思路為:檢查3306埠是否啟動,ps檢視mysqld程式是否啟動,命令列登入mysql執行語句返回結果,php或jsp程式檢測(需要開發人員開發程式)等等;

方法1:監聽3306埠

#!/bin/bash

#written by mofansheng@2015-10-15

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 baby]# 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 baby]# sh check_mysql.sh

Starting MySQL SUCCESS! 

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

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

[root@localhost baby]# sh check_db.sh

MySQL is running

方法3:雙保險,程式和埠都成功才算mysql服務正常

#!/bin/bash

#written by mofansheng@2015-10-15

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 baby]# cat check_db_client.sh

#!/bin/bash

#written by mofansheng@2015-10-15

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 baby]# sh check_db_client.sh

MySQL is running

©著作權歸作者所有:來自51CTO部落格作者模範生的原創作品,如需轉載,請註明出處,否則將追究法律責任

linuxmysqlshellShell指令碼


來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/2157/viewspace-2820507/,如需轉載,請註明出處,否則將追究法律責任。

相關文章