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

來源:互聯網
上載者:User

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

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

方法1:監聽3306連接埠

#!/bin/bash
#written by bkjia@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 bkjia@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 bkjia@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 bkjia@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

本文永久更新連結地址:

相關文章

Alibaba Cloud 10 Year Anniversary

With You, We are Shaping a Digital World, 2009-2019

Learn more >

Apsara Conference 2019

The Rise of Data Intelligence, September 25th - 27th, Hangzhou, China

Learn more >

Alibaba Cloud Free Trial

Learn and experience the power of Alibaba Cloud with a free trial worth $300-1200 USD

Learn more >

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。