Shell腳本實(shí)現(xiàn)監(jiān)控MySQL主從同步
代碼如下:
#!/bin/bash
#check MySQL_Slave Status
#crontab time 00:10
MYSQLPORT=`netstat -na|grep "LISTEN"|grep "3306"|awk -F[:" "]+ '{print $4}'`
MYSQLIP=`ifconfig eth0|grep "inet addr" | awk -F[:" "]+ '{print $4}'`
STATUS=$(/usr/local/webserver/mysql/bin/mysql -u yuhongchun -pyuhongchun101 -S /tmp/mysql.sock -e "show slave status\G" | grep -i "running")
IO_env=`echo $STATUS | grep IO | awk ' {print $2}'`
SQL_env=`echo $STATUS | grep SQL | awk '{print $2}'`
DATA=`date +"%y-%m-%d %H:%M:%S"`
if [ "$MYSQLPORT" == "3306" ]
then
echo "mysql is running"
else
mail -s "warn!server: $MYSQLIP mysql is down" yuhongchun027@163.com
fi
if [ "$IO_env" = "Yes" -a "$SQL_env" = "Yes" ]
then
echo "Slave is running!"
else
echo "####### $DATA #########">> /data/data/check_mysql_slave.log
echo "Slave is not running!" >> /data/data/check_mysql_slave.log
echo "Slave is not running!" | mail -s "warn! $MYSQLIP MySQL Slave is not running" yuhongchun027@163.com
fi
建議每十分鐘運(yùn)行一次
*/10 * * * * root /bin/sh /root/mysql_slave.sh
記得在每臺(tái)MySQL從機(jī)上分配一個(gè)yuhongchun的用戶,權(quán)限大些也沒(méi)關(guān)系,只限定在本地運(yùn)行,如下所示:
grant all privileges on *.* to "yuhongchun"@"127.0.0.1" identified by "yuhongchun101";
grant all privileges on *.* to "yuhongchun"@"localhost" identified by "yuhongchun101";
腳本設(shè)計(jì)思路:
1、此腳本應(yīng)該能適應(yīng)各種各樣不同的內(nèi)外網(wǎng)環(huán)境,即IP不同的環(huán)境;
2、讓腳本也順便監(jiān)控下MySQL是否正常運(yùn)行;
3、Slave機(jī)器的IO和SQL狀態(tài)都必須為YES,缺一不可,這里用到了多重條件判斷-a。
腳本產(chǎn)生的背景環(huán)境:
我有不少基于公網(wǎng)類型的網(wǎng)站(沒(méi)有硬件防火墻,直接置于IDC機(jī)房)做的都是MySQL主從架構(gòu),從機(jī)主要起備份數(shù)據(jù)庫(kù)和冷備份的作用,雖然從機(jī)宕機(jī)了問(wèn)題不大,但也影響數(shù)據(jù)的備份工作;這樣的網(wǎng)站有數(shù)十個(gè),如果一個(gè)一個(gè)手動(dòng)的檢查,每天都要浪費(fèi)不少時(shí)間,所以玩了下腳本控,設(shè)計(jì)了如上腳本。
腳本實(shí)踐:
此腳本我已用于了生產(chǎn)環(huán)境,大家可以放在我們的從MySQL機(jī)器上,用來(lái)監(jiān)控;另外建議有時(shí)也手動(dòng)檢查下,有次發(fā)現(xiàn)rsync --delete 自動(dòng)刪除了/data/data里面的數(shù)據(jù),即從數(shù)據(jù)庫(kù)的位置,腳本沒(méi)有報(bào)警。
后期應(yīng)用:
后期公司的MySQL數(shù)據(jù)庫(kù)準(zhǔn)備由一主一從架色升級(jí)成一主多從,讀寫(xiě)分離的架構(gòu),LVS作從數(shù)據(jù)庫(kù)的負(fù)載均衡器,此腳本自動(dòng)監(jiān)控從MySQL的replication狀態(tài),如果不能同步則自動(dòng)關(guān)閉本機(jī)的MySQL服務(wù),免得影響整個(gè)網(wǎng)站的正常業(yè)務(wù)訪問(wèn)。當(dāng)然了,到時(shí)腳本的運(yùn)行周期肯定也需要更改,由10分鐘變成秒級(jí)的,這個(gè)可以通過(guò)while循環(huán)來(lái)實(shí)現(xiàn)。
相關(guān)文章
Shell命令之?dāng)?shù)組表示語(yǔ)法學(xué)習(xí)
這篇文章主要為大家介紹了Shell命令之?dāng)?shù)組表示語(yǔ)法學(xué)習(xí),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-05-05touch shell腳本并修改為777權(quán)限的方法
這篇文章主要介紹了touch shell腳本并修改為777權(quán)限的方法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-06-06淺談Shell腳本參數(shù)與交互及常見(jiàn)問(wèn)題
本文主要介紹了Shell腳本參數(shù)與交互,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-08-08shell 操作釘釘機(jī)器人實(shí)現(xiàn)告警提醒的方法
這篇文章主要介紹了shell 操作釘釘機(jī)器人實(shí)現(xiàn)告警提醒的方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-05-05Shell編程中的特殊變量之進(jìn)程狀態(tài)變量介紹
這篇文章主要介紹了Shell編程中的特殊變量之進(jìn)程狀態(tài)變量介紹,本文講解了$$、$!、$?、$@、$_這些特殊變量,需要的朋友可以參考下2014-12-12