Mysql

关注公众号 jb51net

关闭
首页 > 数据库 > Mysql > MYSQL 监控方式

一文详解MYSQL最朴素的监控方式

作者:京东云开发者

对于当前数据库的监控方式有很多,分为数据库自带、商用、开源三大类,每一种都有各自的特色,那我们今天就介绍一下完全采用mysql自有方式采集获取监控数据,在单体下达到最快速、方便、损耗最小,感兴趣的同学可以借鉴阅读

本次文章完全使用mysql自带的show命令实现获取,从connects、buffercache、lock、SQL、statement、Database throughputs、serverconfig7大方面全面获取监控数据。

1 连接数(Connects)

2 缓存(bufferCache)

3 锁(lock)

备注:锁等待统计得数量为累加数据,每次获取得时候可以跟之前得数据进行相减,得到当前统计得数据

4 SQL

备注:当mysqldumpslow命令执行失败时,将慢日志同步到本地进行格式化处理。

5 statement

6 吞吐(Database throughputs)

7 数据库参数(serverconfig)

show variables

8 慢SQL

慢SQL指的是MySQL慢查询,具体指运行时间超过long_query_time值的SQL。
我们常听MySQL中有二进制日志binlog、中继日志relaylog、重做回滚日志redolog、undolog等。针对慢查询,还有一种慢查询日志slowlog,用来记录在MySQL中响应时间超过阀值的语句。慢SQL对实际生产业务影响是致命的,所以测试人员在性能测试过程中,对数据库SQL语句执行情况实施监控,给开发提供准确的性能优化意见显得尤为重要。那怎么使用Mysql数据库提供的慢查询日志来监控SQL语句执行情况,找到消耗较高的SQL语句,以下详细说明一下慢查询日志的使用步骤:

常见用法:

注意: 使用mysqldumpslow的分析结果不会显示具体完整的sql语句,只会显示sql的组成结构;
假如: SELECT FROM sms_send WHERE service_id=10 GROUP BY content LIMIT 0, 1000;
mysqldumpslow命令执行后显示:
Count: 2 Time=1.5s (3s) Lock=0.00s (0s) Rows=1000.0 (2000), vgos_dba[vgos_dba]@[10.130.229.196]SELECT
FROM sms_send WHERE service_id=N GROUP BY content LIMIT N, N

mysqldumpslow的分析结果详解:

通过这个工具就可以查询出来哪些sql语句是慢SQL,从而反馈研发进行优化,比如加索引,该应用的实现方式等。

常见慢SQL排查

9 总结

以上就是一文详解MYSQL最朴素的监控方式的详细内容,更多关于MYSQL 监控方式的资料请关注脚本之家其它相关文章!

您可能感兴趣的文章:
阅读全文