多多色-多人伦交性欧美在线观看-多人伦精品一区二区三区视频-多色视频-免费黄色视屏网站-免费黄色在线

國內最全IT社區平臺 聯系我們 | 收藏本站
阿里云優惠2
您當前位置:首頁 > 數據庫 > 數據庫應用 > Nagios 里面監控MySQL事務一直RUNNING沒有結束的報警Shell腳本

Nagios 里面監控MySQL事務一直RUNNING沒有結束的報警Shell腳本

來源:程序員人生   發布時間:2014-12-09 08:35:16 閱讀次數:4291次
敘言:
        業務報警定單提交異常,頁面1直沒有反應,排查后是事務沒有提交或回滾致使,想到如果及時監控事務的運行狀態報警出來,那末就能夠及時排查出問題所在,方便運營處理,所以自己就弄了1個shell腳本放在nagios來處理事務報警情況。

1,編寫事務監控腳本 

#!/bin/bash
# author: tim.man
# version: 1.0
# desc: check the RUNNING TRANSACTION over 


ST_OK=0  
ST_WR=1  
ST_CR=2  
ST_UK=3 


TIME_TRX=10


# 提示信息
print_help() {  
    echo "$PROGNAME -w INT -c INT"  
    echo "Options:"  
    echo "  -w/--warning)"  
    echo "     Sets a warning number"  
    echo "  -c/--critical)"  
    echo "     Sets a critical level for io"  
    exit $ST_UK  
}


while test -n "$1"; do  
    case "$1" in  
        -help|-h)  
            print_help  
            exit $ST_UK  
            ;;  
        --warning|-w)  
            warning=$2  
        shift  
            ;;  
        --critical|-c)  
            critical=$2  
        shift  
            ;;  
        *)  
            echo "Unknown argument: $1"  
            print_help  
            exit $ST_UK  
            ;;  
        esac  
    shift  
done  




get_wcdiff() {  
    if [ ! -z "$warning" -a ! -z "$critical" ]  
    then  
        wclvls=1  
  
        if [ ${warning} -gt ${critical} ]  
        then  
            wcdiff=1  
        fi  
    elif [ ! -z "$warning" -a -z "$critical" ]  
    then  
        wcdiff=2  
    elif [ -z "$warning" -a ! -z "$critical" ]  
    then  
        wcdiff=3  
    fi  
}  


# 腳本判斷
val_wcdiff() {  
    if [ "$wcdiff" = 1 ]  
    then  
        echo "Please adjust your warning/critical thresholds. The warning must be lower than the critical level!"  
        exit $ST_UK  
    elif [ "$wcdiff" = 2 ]  
    then  
        echo "Please also set a critical value when you want to use warning/critical thresholds!"  
        exit $ST_UK  
    elif [ "$wcdiff" = 3 ]  
    then  
        echo "Please also set a warning value when you want to use warning/critical thresholds!"  
        exit $ST_UK  
    fi  
}  


get_wcdiff  
val_wcdiff  


# 統計mysql的事務中最大運行時間
max_over_time=`/usr/local/mysql/bin/mysql --user=nagios --password="nagiosq@xxx"  -NS /usr/local/mysql/mysql.sock -e "SELECT TIME_TO_SEC(TIMEDIFF(NOW(),t.trx_started)) FROM information_schem
a.INNODB_TRX t WHERE TIME_TO_SEC(TIMEDIFF(NOW(),t.trx_started))>$TIME_TRX ORDER BY TIME_TO_SEC(TIMEDIFF(NOW(),t.trx_started)) DESC LIMIT 1;" |awk '{print $1}'`


# 如果當前沒有RUNNING的事務,則直接賦值為0,以避免下面if判斷出錯
if [ ! -n "$max_over_time" ];then max_over_time=0 
fi


# 獲得當前所以阻塞的事務數量
num_trx=`/usr/local/mysql/bin/mysql --user=nagios --password="nagiosq@xxx"  -NS /usr/local/mysql/mysql.sock -e "SELECT COUNT(1) FROM information_schema.INNODB_TRX t WHERE TIME_TO_SEC(TIMEDIF
F(NOW(),t.trx_started))>$TIME_TRX;" |awk '{print $1}'`


if [ -n "$warning" -a -n "$critical" ]  
then  
    if [ `expr $max_over_time > $warning` -eq 1 -a `expr  $max_over_time < $critical` -eq 1 ]  
    then  
        echo "WARNING - $num_trx TRANSACTIONS RUNNING,go over for $max_over_time seconds"  
        exit $ST_WR  
    elif [ `expr $max_over_time > $critical` -eq 1 ]  
    then  
        echo "CRITICAL- $num_trx TRANSACTIONS RUNNNING,go over for $max_over_time seconds"  
        exit $ST_CR  
    else  
        echo "OK- TRANSACTIONS RAN successfully."  
        exit $ST_OK  
    fi  
fi


2,在nagios客戶端添加腳本監控
先測試下腳本
[root@wgq_idc_dbm_3_61 binlog]# /usr/local/nagios/libexec/check_trx -w 30 -c 60
Warning: Using a password on the command line interface can be insecure.
Warning: Using a password on the command line interface can be insecure.
OK- TRANSACTIONS RAN successfully.

[root@wgq_idc_dbm_3_61 binlog]#


在nrpe.cfg里面添加監控命令
[root@wgq_idc_dbm_3_61 binlog]# vim /usr/local/nagios/etc/nrpe.cfg
command[check_mysql_trx]=/usr/local/nagios/libexec/check_trx -w 30 -c 60

以后重啟nagios客戶端監控, service nrpe restart




4,在nagios主監控服務器上面添加配置選項
先去nagios服務器上面check1下
[root@localhost etc]# /usr/local/nagios/libexec/check_nrpe -H10.254.3.61 -c check_mysql_trx
OK- TRANSACTIONS RAN successfully.
[root@localhost etc]# 

在services.cfg里面添加事務監控選項:
define service{
        host_name               mysqlserver
        service_description     Check mysql transctions
        check_command           check_nrpe!check_mysql_trx
        max_check_attempts      5
        check_command           check_nrpe!check_mysql_trx
        max_check_attempts      5
        normal_check_interval   3
        retry_check_interval    2
        check_period            24x7
        notification_interval   10
        notification_period     24x7
        notification_options    w,u,c,r
        contact_groups          opsweb
        }

在commands.cnf里面添加事務監控命令:
# add by tim.man on 20141201
define command{
        command_name    check_mysql_trx
        command_line    $USER1$/check_mysql_trx -w $ARG1$ -c $ARG2$
        }

郵件短信報警電話報警已添加,所以無需重新配置。

然后重新加載nagios
[root@localhost objects]# service nagios reload
Running configuration check...
Reloading nagios configuration...
done
[root@localhost objects]# 



5,去nagios主監控界面查看監控效果


正常監控效果:



嚴重監控效果:



----------------------------------------------------------------------------------------------------------------
<版權所有,允許轉載,但必須以鏈接方式注明源地址,否則追究法律責任!>
原博客地址:   http://blog.itpub.net/26230597/viewspace⑴355720/
原作者:黃杉 (mchdba)
----------------------------------------------------------------------------------------------------------------
生活不易,碼農辛苦
如果您覺得本網站對您的學習有所幫助,可以手機掃描二維碼進行捐贈
程序員人生
------分隔線----------------------------
分享到:
------分隔線----------------------------
關閉
程序員人生
主站蜘蛛池模板: 99色吧 | 欧洲久久| 玖玖色资源站 | 精品日韩一区二区三区 | 亚洲第一网站在线观看 | 国产精品久久久久久久久久久威 | 亚洲最大色网站 | 亚欧乱色 | 最近中文字幕免费完整 | 国产成人综合亚洲一区 | 欧美啊v在线 | 中国毛片免费观看 | www 在线播放| 日韩免费专区 | 欧美3区| 中文字幕在线视频免费 | 亚洲区小说区激情区图片区 | 国产成人综合亚洲一区 | 色午夜日本高清视频www | 午夜羞羞 | 色综合天天综合网国产成人 | 福利片中文 | 亚洲区小说区图片区qvod | 一级日韩 | 请看一下欧美一级毛片 | 亚洲日本黄色 | 91亚洲欧美综合高清在线 | 亚洲欧美日本国产 | 免费中日高清无专码有限公司 | 成人一a毛片免费视频 | 免费麻豆国产一区二区三区四区 | 亚洲在线小视频 | 国产高清不卡一区二区三区 | 天堂入口| 欧美成人免费全部色播 | 午夜视频网 | 另类天堂网 | 亚洲免费黄色网址 | 91精品久久久久久久久中文字幕 | 亚洲五月激情 | 欧美一级视屏 |