標籤:linux shell shell編程 mysql
監控MySQL服務是否正常,通常的思路為:檢查3306連接埠是否啟動,ps查看mysqld進程是否啟動,命令列登入mysql執行語句返回結果,php或jsp程式檢測(需要開發人員開發程式)等等;
方法1:監聽3306連接埠
#!/bin/bash#written by [email protected]port=`netstat -nlt|grep 3306|wc -l`if [ $port -ne 1 ]then /etc/init.d/mysqld startelse echo "MySQL is running"fi
方法2:查看mysqld進程
注意注意:如果使用進程過濾的話,指令碼名稱如果裡麵包含mysql的話,指令碼執行有坑,切記!!!因為會把指令碼也grep了一次,導致結果不準確;
[[email protected] baby]# cat check_mysql.sh#!/bin/bash#written by [email protected]process=`ps -ef |grep mysql|grep -v grep |wc -l`if [ $process -ne 2 ]then /etc/init.d/mysqld startelse echo "MySQL is running"fi
執行結果如下:
[[email protected] baby]# sh check_mysql.sh
Starting MySQL SUCCESS!
改名之後執行為正常結果:
[[email protected] baby]# mv check_mysql.sh check_db.sh
[[email protected] baby]# sh check_db.sh
MySQL is running
方法3:雙保險,進程和連接埠都成功才算mysql服務正常
#!/bin/bash#written by [email protected]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 startfi
4:使用用戶端登入mysql執行命令,查看返回結果測試服務是否啟動,理論上此方法最可靠。
[[email protected] baby]# cat check_db_client.sh#!/bin/bash#written by [email protected]mysql -uroot -p123456 -e "select version();" &>/dev/nullif [ $? -ne 0 ]then /etc/init.d/mysqld startelse echo "MySQL is running"fi
執行結果如下:
[[email protected] baby]# sh check_db_client.sh
MySQL is running
本文出自 “模範生的學習部落格” 部落格,請務必保留此出處http://mofansheng.blog.51cto.com/8792265/1703285
shell指令碼:監控MySQL服務是否正常