MySQL慢日志监控脚本实例剖析
公司线上的 MySQL 慢日志,之前一直没有做好监控。趁着上周空闲,我就把监控脚本写了下,今天特地把代码发出来与51博友分享一下。
针对脚本的注解和整体构思,我会放到脚本之后为大家详解。
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
|
#!/bin/bash## 本脚本用来在指定频率内监控 MySQL 慢日志的变化,并在发生增长时及时报警# Written by sunsky# Mail : 274546888@qq.com# Date : 2014-11-17 10:00:00#MON_FILE="$2" # 指定所要监控的脚本路径SEC=60 # 指定所要监控的频率,即间隔多久去查看一次MON_POINT_FILE=/tmp/mon_mysql_slow.point # 指定MySQL慢日志的监控点存放的路径DIFF_MON_FILE=/tmp/mon_mysql_slow.log # 指定在监控频率内增加的MySQL慢日志信息存放路径ADMIN_MAIL=liuhao@51baturu.com # 指定发送给哪个管理员function USAGE { echo -e "\033[31m脚本名称: \033[37m" echo " $0" echo -e "\033[31m语法结构: \033[37m" echo " $0 {start|stop|restart} MySQL慢日志文件路径" echo -e "\033[31m使用范例: \033[37m" echo " $0 start /usr/local/mysql/log/mysql_slow.log" echo " $0 stop" echo " $0 restart /usr/local/mysql/log/mysql_slow.log" echo -e "\033[31m注意事项: \033[37m" echo " 1. 除了stop操作,start和restart操作时,\$2 参数不能为空" echo " 2. \$2 参数指定的文件必须存在" exit 2}function start { echo "MySQL慢日志监控进程已经启动,监控文件为 $MON_FILE ,监控频率为 ${SEC}s一次." while : do [ -f $MON_POINT_FILE ] || echo 0 > $MON_POINT_FILE NEW_POINT=$(awk 'END{print NR}' $MON_FILE) OLD_POINT=$(<$MON_POINT_FILE) [[ -z $OLD_POINT ]]&&OLD_POINT=0 SUM_POINT0=$(($NEW_POINT-$OLD_POINT)) SUM_POINT=${SUM_POINT0#-} tail -$SUM_POINT $MON_FILE > $DIFF_MON_FILE if [[ -s $DIFF_MON_FILE ]];then sed -i '1i 本次新增慢日志 '$SUM_POINT' 条' $DIFF_MON_FILE mail -s "[警告] 服务器 $(hostname) 产生 MySQL 慢日志 $SUM_POINT 条" $ADMIN_MAIL < $DIFF_MON_FILE > $DIFF_MON_FILE echo $NEW_POINT > $MON_POINT_FILE fi sleep ${SEC}s done}function stop { if [[ -n `ps -ef|awk '$0~"mon_mysql_slow_log.sh"{print $2}'` ]]; then for PID in `ps -ef|awk '$0~"mon_mysql_slow_log.sh"{print $2}'`; do [[ $PID != $$ ]] && kill -9 $PID >& /dev/null done else echo '目前暂无MySQL慢日志监控进程' exit 0 fi echo 'MySQL慢日志监控进程已经停止运行'}function restart { stop start &}if [[ $1 == stop ]] then : else [[ $2 < 3 ]] && USAGE [[ ! -f $2 ]] && USAGEficase $1 in start) start & ;; stop) stop ;; restart) MON_FILE=$2 restart ;; *) USAGE ;;esac |
OK!
以上就是脚本的全部内容。整个脚本由四个主函数构成。针对每个函数的作用,我这里做下介绍:
|
1
2
3
4
|
USAGE # 该函数负责提示用户如何正确使用该脚本start # 该函数负责启动脚本stop # 该函数负责停止监控脚本restart # 该函数负责重启监控脚本 |
下面附上脚本的使用效果图:

脚本的整个思路就是,通过while :;do statement;done启一个死循环,然后在死循环里面通过 sleep 来控制死循环的循环间隔。在指定的循环间隔内,通过取MySQL慢日志的长度作为一个记录点,然后在下一个循环到来时,通过比对上一个记录点来得出,日志是否有变化。如果有变化,就通过计算记录点的差值来得出增长值。通过增长值来获取到增长的这部分日志,然后通过mail发送到指定的管理员邮箱。
这里展示下发送出来的邮件:

OK!其它的一看就懂,这里就不废话了。
本文到此结束,希望能对51博友有所帮助!
MySQL慢日志监控脚本实例剖析的更多相关文章
- shell监控脚本实例—监控mysql主从复制
分享一例shell脚本,用于监测mysql数据库的主从复制,有需要的朋友不妨参考学习下. 转自:http://www.jbxue.com/article/14103.html(转载请注明出处) 本节内 ...
- tomcat错误日志监控脚本
#!/usr/bin/env python #-*-coding:utf-8-*- #CreateDate:2017/04/14 #Author:Eivll0m #ScriptName:monitor ...
- mysql复制延迟监控脚本
#!/bin/sh #ocpyang@126.com #repdelay.sh #查看复制延迟详细多少event #####1.juede the rep slave status export bl ...
- centos shell编程6一些工作中实践脚本 nagios监控脚本 自定义zabbix脚本 mysql备份脚本 zabbix错误日志 直接送给bc做计算 gzip innobackupex/Xtrabackup 第四十节课
centos shell编程6一些工作中实践脚本 nagios监控脚本 自定义zabbix脚本 mysql备份脚本 zabbix错误日志 直接送给bc做计算 gzip innobacku ...
- MySQL监控脚本
zabbix监控mysql时自定key用到的脚本 #!/usr/bin/env python #-*- coding: UTF-8 -*- from __future__ import print_f ...
- shell脚本实例-系统监控
shell脚本监控网站并实现邮件.短信报警shell进程监控脚本(发送邮件报警)Shell脚本监控服务器在线状态和邮件报警的方法 http://www.jbxue.com/jb/shell/ 11. ...
- Linux centosVMware 告警系统主脚本、告警系统配置文件、告警系统负载脚本、告警系统502日志脚本、告警系统disk监控脚本、告警系统邮件引擎
一.告警系统主脚本 要求:我们的机器角色多种多样,但是所有机器上都要部署同样的监控系统,也就说所有机器不管什么角色,整个程序框架都是一致的,不同的地方在于根据不同的角色,定制不同的配置文件. 程序架构 ...
- 关于mysql和Apache以及nginx的监控脚本怎么写会比较好的记录
最近,自己业务进行上线,上线后,需要考虑的是对各种服务进行监控,包括(httpd服务,mysqld服务等),现在想以mysqld服务为例总结下那种方式的脚本最为专业和合理: (1).根据mysql的端 ...
- 【mysql】使用脚本对mysql状态进行监控
1.mysqladmin 使用mysqladmin extended-status命令可以获得所有MySQL性能指标,即show global status的输出,不过,因为多数这些指标都是累计值,如 ...
随机推荐
- Leetcode 83 Remove Duplicates from Sorted List 链表
就是将链表中的重复元素去除 我的方法很简单就是如果链表的前后元素相同的话,将后一个元素删除 /** * Definition for singly-linked list. * struct List ...
- 大家一起写mvc(三)_结束
上一篇介绍到要写mvc的所用的核心技术,这一篇我们就开始真正的开始写mvc,其实就是把昨天写过的代码进行一些组装就可以了. 我们用eclipse新建一个web项目.然后web.xml如下 <?x ...
- 统计项目的java代码总行数
http://www.oschina.net/code/snippet_209431_7358 wc -l $(find . -type f -name '*.java')
- Android中使用自定义View实现下载进度的显示
一般有下载功能的应用都会有这样一个场景,需要一个图标来标识不同的状态.之前在公司的项目中写过一个,今天抽空来整理一下. 一般下载都会有这么几种状态:未开始.等待.正在下载.下载结束,当然有时候会有下载 ...
- IOS适配
• Default.png(图片尺寸为320x480):显示在非Retina-3.5英寸屏幕上(iPhone3G\iPhone3GS,屏幕分辨率为320x480) • Default@2x.png(图 ...
- 【Android开发坑系列】之经常被忽略的背景图片内存泄露
我们平时设置图片的时候,几乎都忘记回收老的(背景)图片,比如: TextView.setBackgroundDrawable() TextView.setBackgroundResource() Im ...
- dubbo 管理控制台 的安装 dubbo-admin
按照官方文档来,只是官方文档中提供的war包无法下载,我的环境至少是这样,不知道其他网络环境是否OK. war包下载地址:链接: http://pan.baidu.com/s/1i32fs7j 密码: ...
- 使用ClipboardUtils兼容API LEVEL 11以下实现复杂粘贴
实现功能:复杂粘贴内容 问题描述:android.content.ClipboardManager在APILevel 11之后才可以使用,而我们目前还要兼容API Level 10(2.3.3) 解决 ...
- 高并发WCF配置
在使用WCF做服务接口时,TCP模式肯定比Http效率高,Binary/MTOM格式的绑定也会Text格式的绑定高效. 两个endpoint,一个用来调试:ms-mex的binding是用来方便WCF ...
- Git + BeyondCompare
Mac 环境: 1. 安装 BeyondCompare 2. 配置 ~/.gitconfig [diff] tool = bcomp [merge] tool = bcomp [difftool &q ...