序言:

业务报警订单提交异常,页面一直没有反应,排查后是事务没有提交或者回滚导致,想到如果及时监控事务的运行状态报警出来,那么就可以及时排查出问题所在,方便运营处理,所以自己就弄了一个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="[email protected]"  -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="[email protected]"  -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客户端添加脚本监控

先测试下脚本

[[email protected]_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.

[[email protected]_idc_dbm_3_61 binlog]#

在nrpe.cfg里面添加监控命令

[[email protected]_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服务器上面check一下

[[email protected] etc]# /usr/local/nagios/libexec/check_nrpe -H10.254.3.61 -c check_mysql_trx

OK- TRANSACTIONS RAN successfully.

在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

[[email protected] objects]# service nagios reload

Running configuration check...

Reloading nagios configuration...

done

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

正常监控效果:

严重监控效果:

----------------------------------------------------------------------------------------------------------------

原博客地址:   http://blog.itpub.net/26230597/viewspace-1355720/

原作者:黄杉 (mchdba)

----------------------------------------------------------------------------------------------------------------

原文:http://blog.itpub.net/26230597/viewspace-1355720/

mysql+实例夯住的监控_Nagios 里面监控MySQL 监控事务夯住(RUNNING)报警通知相关推荐

  1. Windows下的MySQL实例没有mysql.user表#Olivia丶长歌#

    原因:在Windows下安装MySQL实例过程中没有勾选配置选项mysql server instance configuration wizard. 临时解决办法:在/mysq/bin/目录下执行m ...

  2. 一台服务器可以安装多个mysql数据库_在一台Linux服务器上安装多个MySQL实例(一)--使用mysqld_multi方式...

    (一)MySQL多实例概述 实例是进程与内存的一个概述,所谓MySQL多实例,就是在服务器上启动多个相同的MySQL进程,运行在不同的端口(如3306,3307,3308),通过不同的端口对外提供服务 ...

  3. 如何实现一台机器上运行多个MySQL实例?

    在一台机器上一个MySQL服务器运行多个MySQL实例有什么好处?这里我先入为主给大家介绍这样做至少存在两个好处(看完这篇文章后理解会更透彻): (1)减轻服务器链接负担 (2)为不同的用户提供不同的 ...

  4. php链接mysql实例之用户登录验证以及使用cookie登录

    这篇博客实现用户登录验证以及使用cookie登录,它承接了前面的几个博客: 1. php连接mysql实例之新用户注册实现 2. php连接mysql实例之后台列表显示已注册的用户信息 3. php连 ...

  5. shel脚本mysql锁表_centos下shell脚本kill掉mysql锁表进程【笔记】

    前几天发现服务器上的mysql出现锁表了,show processlist后发现好多都是因为写进session才锁表的,看到这个想起了会不会是硬盘空间不够了,马上查看了服务器硬盘空间,发现都100%了 ...

  6. 《MySQL 8.0 参考手册》第 14 章 MySQL 数据字典

    文章目录 14.1 数据字典模式 数据字典升级过程 使用 MySQL 调试版本查看数据字典表 14.2 删除基于文件的元数据 14.3 事务型数据字典 14.4 数据字典缓存 14.5 INFORMA ...

  7. 华为 mysql实例监控,华为云文档数据库服务DDS监控告警全新优化

    "哎哎,小刘,那个很多客服反馈这个业务挂了怎么回事,赶紧看看." 正在安安静静写代码的你突然心头一颤,出问题了?于是赶紧打开业务链接,一看,果真出问题了.这可怎么办?怎么查问题呢? ...

  8. 京东如何基于Vitess管理大型MySQL实例集群

    本文根据dbaplus社群第203期线上分享整理而成 讲师介绍 王云博 京东数据库高级研发工程师 2014年加入京东,一直致力于数据库运维自动化的发展: 2018年专注于京东弹性数据库研发.运维工作. ...

  9. 函数计算支持 MySQL 实例绑定

    函数计算(Function Compute):函数计算 是事件驱动的全托管计算服务.使用函数计算,您无需采购与管理服务器等基础设施,只需编写并上传代码.函数计算为您准备好计算资源,弹性地可靠地运行任务 ...

最新文章

  1. android StringBuffer的使用
  2. CodeChef Chef and Churu [分块]
  3. linux视频在windows播放器,适用于Windows和Linux的免费多媒体播放器SMPlayer 18.6.0发布 - 爱绿豆...
  4. oracle更新前触发器,Oracle之前更新触发器
  5. Spark Runtime概述
  6. html 图片循环轮播,如何在Web端实现动画切换效果一致的无限循环图片轮播?
  7. Excel 冻结窗口
  8. 苹果开发者账号双重认证
  9. vue-lunar-full-calendar日程控件加农历、24节气和中国节假日的功能
  10. sap的清账是什么意思_sap F-30 什么时候会用到 过账并清帐是什么意思
  11. 比较两条曲线的相似程度
  12. 将/etc/passwd文件的内容写入/tmp/passwd文件中
  13. [转载]命令行也强大之下载迅雷资源的方法
  14. SIMCom芯片关于GPS定位信息的的解析(AT+CGNSINF)
  15. 【百金轻】:油价跌势愈猛 投资者更不应做急单
  16. 爆炸的符卡洋洋洒洒题解
  17. 1024,只有程序员才会翘首以盼的日子!
  18. Python爬虫日记-解释def __init__(self, *args, **kwargs)
  19. Twitter分享失败,HTTP 403 error
  20. 电饼锅的样式图片价格_大型商用电饼铛价格及图片

热门文章

  1. android 在使用ViewAnimationUtils.createCircularReveal()无法兼容低版本的情况下,另行实现圆形scale动画...
  2. SQLAlchemy技术文档(中文版)(中)
  3. 转载模板声明中template typename T和template class T
  4. 支持插件的消息中间件【msg broker with plugin】 - 知然 - 博客园
  5. 网路游侠:某厂家新发布的数据销毁工具
  6. JSP实现在线调查问卷系统
  7. 单例模式 之 单例模式——饿汉模式
  8. SQL语句大全,所有的SQL都在这里
  9. kettle安装部署及远程执行
  10. SpringBoot(十二):springboot如何测试打包部署