隨著(zhù)應用系統的不斷增加,原本不告警的active threads,開(kāi)始頻繁告警(一天2次左右)。雖然告警次數不多,而且該監控項舍得閾值不高(不超過(guò)50),但對于運維來(lái)說(shuō)數據庫的threads-running是一個(gè)必須要重視的點(diǎn)。
一般告警出現在半夜,不可能靠人工去記錄threads-running過(guò)線(xiàn)后,到底哪些連接正在處理。市面上也沒(méi)好的工具能自動(dòng)記錄這些數據,所以這時(shí)候就需要zabbix的action功能了。
1. 定義監控項
這里偷個(gè)懶,直接使用了percona模板中Threads Running監控項:
2. 定義觸發(fā)器
同樣適用percona的觸發(fā)器設置:
3. 創(chuàng )建action
按照下圖的順序創(chuàng )建action:
4. action條件
A、B、C、D條件都滿(mǎn)足,才會(huì )觸發(fā)動(dòng)作,這里盡量篩選的詳細點(diǎn),免得出現zabbix錯誤調用的情況。
5. 完善操作內容
這里適用ssh方式,當然你也可以在類(lèi)型欄使用自定義腳本選項,就是要多給zabbix客戶(hù)端賦sudo權限。
命令欄填的是/bin/sh /opt/connect.sh命令,這個(gè)很好理解,直接調用connect.sh腳本,具體腳本附在后文中。
6. 修改zabbix-agent配置
進(jìn)入被監控服務(wù)器:
vim /etc/zabbix/zabbix_agentd.conf EnableRemoteCommands=1 #增加這項參數,意思是允許zabbix server遠程命令 service zabbix-agent restart
至此,zabbix相關(guān)的配置均已完成,接下來(lái)只需要將寫(xiě)好的處理腳本放入/opt目錄即可。
這次要實(shí)現的是,在連接超過(guò)50個(gè)時(shí),輸出到底是哪個(gè)賬號、哪個(gè)ip、在執行哪個(gè)sql等信息。腳本如下:
#!/bin/sh export PATH=$PATH:/usr/bin da=`date +%Y%m%d` dc=`date +%Y-%m-%d" "%H:%M:%S` echo $dc"-------------------------------我是分割線(xiàn)------------------------------------" >> /tmp/ok_$da.log /usr/local/mysql/bin/mysql -uroot -pXXX -e "select * from information_schema.PROCESSLIST where COMMAND != 'Sleep' order by TIME DESC;" >> /tmp/ok_$da.log
既然zabbix在報警時(shí)可以調用腳本,那是不是可以讓zabbix處理點(diǎn)更為復雜的工作?
數據庫連接、鎖、存儲引擎等信息
#!/bin/sh export PATH=$PATH:/usr/bin da=`date +%Y%m%d` dc=`date +%Y-%m-%d" "%H:%M:%S` echo $dc"-------------------------------我是分割線(xiàn)------------------------------------" >> /home/zabbix/engine_log/engine_log_$da.log /usr/bin/mysql -hlocalhost -uroot -pXXX -e "show engine innodb status \G;" >> /home/zabbix/engine_log/engine_log_$da.log echo -e "\n\n\n" >> /home/zabbix/engine_log/engine_log_$da.log echo $dc"-------------------------------我是分割線(xiàn)------------------------------------" >> /home/zabbix/processlist/processlist_$da.log /usr/bin/mysql -hlocalhost -uroot -pXXX -e "select * from information_schema.processlist where time>=0 and command !='sleep' order by time desc \G;" >> /home/zabbix/processlist/processlist_$da.log echo -e "\n\n\n" >> /home/zabbix/processlist/processlist_$da.log echo $dc"-------------------------------我是分割線(xiàn)------------------------------------" >> /home/zabbix/lock/lock_$da.log /usr/bin/mysql -hlocalhost -uroot -pXXX -e "select 'Blocker' role, p.id, p.user, left(p.host, locate(':', p.host) - 1) host, tx.trx_id, tx.trx_state, tx.trx_started, timestampdiff(second, tx.trx_started, now()) duration, lo.lock_mode, lo.lock_type, lo.lock_table, lo.lock_index, tx.trx_query, tx.trx_tables_in_use, tx.trx_tables_locked, tx.trx_rows_locked from information_schema.innodb_trx tx, information_schema.innodb_lock_waits lw, information_schema.innodb_locks lo, information_schema.processlist p where lw.blocking_trx_id = tx.trx_id and p.id = tx.trx_mysql_thread_id and lo.lock_trx_id = tx.trx_id union all select 'Blockee' role, p.id, p.user, left(p.host, locate(':', p.host) - 1) host, tx.trx_id, tx.trx_state, tx.trx_started, timestampdiff(second, tx.trx_started, now()) duration, lo.lock_mode, lo.lock_type, lo.lock_table, lo.lock_index, tx.trx_query, tx.trx_tables_in_use, tx.trx_tables_locked, tx.trx_rows_locked from information_schema.innodb_trx tx, information_schema.innodb_lock_waits lw, information_schema.innodb_locks lo, information_schema.processlist p where lw.requesting_trx_id = tx.trx_id and p.id = tx.trx_mysql_thread_id and lo.lock_trx_id = tx.trx_id \G;" >> /home/zabbix/lock/lock_$da.log echo -e "\n\n\n" >> /home/zabbix/lock/lock_$da.log val=`/usr/bin/mysql -hlocalhost -uroot -pXXX -N -e "show variables like 'general_log'" |awk '{print $2}'` if [ $val = 'OFF' ]; then /usr/bin/mysql -hlocalhost -uroot -pXXX -e "set global general_log=0;" else exit 0; fi
在數據庫壓力大的時(shí)候,可以記錄哥哥鎖信息、連接信息還有存儲引擎信息。所謂壓力大,我們可以將觸發(fā)項定以下幾個(gè):
這些都可以作為觸發(fā)條件。
殺死長(cháng)sql
#!/bin/sh export PATH=$PATH:/usr/bin da=`date +%Y%m%d` dc=`date +%Y-%m-%d" "%H:%M:%S` user="root" password="XXX" val=`mysql -u$user -p$password -N -e "select count(*) from information_schema.processlist where time>=180 and command ='Query' and user in ('job_name','report')" | awk '{print $1}'` if [ $val -gt 0 ]; then echo $dc"-------------------------------我是分割線(xiàn)------------------------------------" >> /home/zabbix/kill_log/long_query_$da.log mysql -u$user -p$password -e "select * from information_schema.processlist where time>=180 and command ='Query' and user in ('job_name','report') order by time desc \G;" >> /home/zabbix/kill_log/long_query_$da.log echo -e "\n\n\n" >> /home/zabbix/kill_log/long_query_$da.log count=`mysql -u$user -p$password -N -e "select id from information_schema.processlist where time>=180 and command ='Query' and user in ('job_name','report')"` for id in $count; do mysql -u$user -p$password -e "kill $id" done else exit 0; fi
有時(shí)候一些job或者報表sql會(huì )長(cháng)時(shí)間在那里執行,導致影響到其他業(yè)務(wù),我們可以簡(jiǎn)單做下判斷,當數據庫連接激增,多數是由于有大sql夯在那里,這時(shí)候可以讓zabbix調用這個(gè)腳本去殺死特殊賬號發(fā)起的超過(guò)180秒的sql。至于kill sql的條件可以在腳本中自定義。
當然了,像這種明知需要很長(cháng)時(shí)間才能處理完的sql,應該放在從庫中去執行。
#!/bin/sh logdir='/mysql/logs' binlog='/mysql/binlog' var_percent=`df -h |grep var|grep dev/sda|awk '{print $5}'|awk -F% '{print $1}'` if [ -z $var_percent ] || [ $var_percent -lt 90 ];then echo "never mind" exit 0 fi date >>$binlog/del_list.txt list=`ls -l --time-style='+%Y-%m-%d %H:%M:%S' $binlog/mysql-bin.0?????|awk '{print $6","$7","$8}'` for i in $list do filetime=`echo $i|awk -F "," '{print $1,$2}'` filetimestamp=`date -d "$filetime" +%s` cur_time=`date +%s` if [ $(($cur_time - $filetimestamp)) -gt $((3*24*3600)) ];then filename=`echo $i|awk -F, '{print $3}'` echo "$filename will delete">>$binlog/del_list.txt /bin/rm $filename fi done if [ -f $logdir/mysql-slow.log ];then slow_log_size=`stat $logdir/mysql-slow.log|grep 'Size:'|awk -F ':' '{print $2}'|awk '{print $1}'` if [ $slow_log_size -gt $((2*1024*1024*1024)) ];then echo "$logdir/mysql-slow.log">>$logdir/del_list.txt /bin/rm $logdir/mysql-slow.log fi fi
有些時(shí)候binlog和slowlog沒(méi)設置自動(dòng)刪除,時(shí)間長(cháng)了會(huì )把磁盤(pán)空間占滿(mǎn)。這時(shí)候我們可以關(guān)聯(lián)Free disk space on /mysql監控項,查過(guò)閾值后,調用上面的腳本去清理無(wú)用的binlog和slowlog。
在有些依賴(lài)binlog的情況下,比如主從中斷,之后還需要恢復的情況下,需要謹慎使用。
通過(guò)zabbix獲取數據庫連接的信息及部分擴展 :
到此這篇關(guān)于通過(guò)zabbix獲取數據庫連接的信息及部分擴展的文章就介紹到這了,更多相關(guān)zabbix數據庫連接內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng )、來(lái)自本網(wǎng)站內容采集于網(wǎng)絡(luò )互聯(lián)網(wǎng)轉載等其它媒體和分享為主,內容觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如侵犯了原作者的版權,請告知一經(jīng)查實(shí),將立刻刪除涉嫌侵權內容,聯(lián)系我們QQ:712375056,同時(shí)歡迎投稿傳遞力量。
Copyright ? 2009-2022 56dr.com. All Rights Reserved. 特網(wǎng)科技 特網(wǎng)云 版權所有 特網(wǎng)科技 粵ICP備16109289號
域名注冊服務(wù)機構:阿里云計算有限公司(萬(wàn)網(wǎng)) 域名服務(wù)機構:煙臺帝思普網(wǎng)絡(luò )科技有限公司(DNSPod) CDN服務(wù):阿里云計算有限公司 百度云 中國互聯(lián)網(wǎng)舉報中心 增值電信業(yè)務(wù)經(jīng)營(yíng)許可證B2
建議您使用Chrome、Firefox、Edge、IE10及以上版本和360等主流瀏覽器瀏覽本網(wǎng)站