如何使用systemtap调试工具分析MySQL的性能

这篇文章将为大家详细讲解有关如何使用systemtap调试工具分析MySQL的性能,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

一、 分析SQL语句在执行各个阶段的消耗

比如我们想统计一句SQL在解析阶段的执行时间,可以在mysqld进程的对应parse_sql函数上加探测点,统计函数执行时间。

如何使用systemtap调试工具分析MySQL的性能

脚本如下:

如何使用systemtap调试工具分析MySQL的性能

示例如下,当前QPS约1.6W,包含了SQL执行过程中解析、redo、binlog、undo、网络、IO读、IO写上的消耗,由于涉及的函数较多,这部分后续还需要整理完善。

如何使用systemtap调试工具分析MySQL的性能

也可以用来分析一句SQL的执行性能:

如何使用systemtap调试工具分析MySQL的性能

二、SQL执行时间统计分布

对于应用来说,主要关心数据库的吞吐量和响应时间,下面从应用负载的角度去衡量,服务器上当前执行SQL语句的性能分布情况。

下图是1秒聚合的SQL语句的执行时间分布图,表示大部分SQL的执行时间在128us以下:

如何使用systemtap调试工具分析MySQL的性能

【性能开销】

用sysbench做了简单压测,并发8线程时,运行stap脚本QPS从3.5W降到3.3W,性能损耗约6%;当并发32线程时,运行stap脚本QPS从9W降到7W,性能损耗约22%

如何使用systemtap调试工具分析MySQL的性能

关于“如何使用systemtap调试工具分析MySQL的性能”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。

原创文章,作者:ItWorker,如若转载,请注明出处:https://blog.ytso.com/tech/database/205141.html

(0)
上一篇 2021年11月29日 19:06
下一篇 2021年11月29日 19:06

相关推荐

发表回复

登录后才能评论