设为首页 收藏本站
查看: 1259|回复: 0

[经验分享] MySQL的SQL Profiler性能分析器

[复制链接]

尚未签到

发表于 2018-10-24 07:38:16 | 显示全部楼层 |阅读模式
  MySQL从5.0开始提供了 SQL Profiler性能分析器,其主要用途是显示 sql 执行的整个过程中各项资源的使用情况。这个工具可以很好的展示出 SQL 的性能问题。
  下面我们从五个角度并举例介绍MySQL SQL Profiler的使用方法(尤其第五个角度,从源码出发,分析了重要的几个项目的含义,便于读者准确掌握其含义):
  一检查是否启用性能分析功能
  mysql> select version();
  +--------------+
  | version() |
  +--------------+
  | 5.6.12 |
  +--------------+
  1 row in set (0.00 sec)
  mysql> SELECT @@profiling;
  +-------------+
  | @@profiling |
  +-------------+
  | 0 |
  +-------------+
  1 row in set, 1 warning (0.00 sec)
  说明:
  0表示没有开启性能分析功能
  二开启性能关系功能
  mysql> SET profiling = 1;
  Query OK, 0 rows affected (0.00 sec)
  三查询获取性能信息
  3.1)显示单条SQL语句的执行过程的性能信息:
SHOW PROFILE [type [, type] ... ]  [FOR QUERY n]
  [LIMIT row_count [OFFSET offset]]
type:  ALL
  | BLOCK IO
  | CONTEXT SWITCHES
  | CPU
  | IPC
  | MEMORY
  | PAGE FAULTS
  | SOURCE
  | SWAPS
  说明
  获取执行过的SQL语句对资源的使用情况。
[FOR QUERY n]表示可以指定获取某个特定的SQL的性能信息,此信息的输出和获取全部SQL语句的输出内容不同,对于查看特定的语句的过程环节,更有帮助。  3.2)显示所有SQL语句的执行情况:
SHOW PROFILE;  四示例
  创建表:
  CREATE TABLE a(col INT);
  CREATE TABLE b(col INT);
  执行SQL:
  mysql> set profiling=1;
  Query OK, 0 rows affected, 1 warning (0.00 sec)
  mysql> EXPLAIN SELECT 1 FROM
  -> a
  -> LEFT JOIN b ON b.col = a.col
  -> RIGHT JOIN a AS T0 ON b.col = a.col
  -> LEFT JOIN a AS T1 ON T1.col = a.col
  -> RIGHT JOIN b AS T2 ON T2.col = a.col
  -> JOIN a AS T3 ON T3.col = a.col
  -> JOIN b AS t4 ON T4.col = a.col;
  +----+-------------+-------+------+---------------+------+---------+------+------+----------------------------------------------------+

  |>  +----+-------------+-------+------+---------------+------+---------+------+------+----------------------------------------------------+
  | 1 | SIMPLE | a | ALL | NULL | NULL | NULL | NULL | 1 | NULL |
  | 1 | SIMPLE | b | ALL | NULL | NULL | NULL | NULL | 1 | Using where; Using join buffer (Block Nested Loop) |
  | 1 | SIMPLE | T0 | ALL | NULL | NULL | NULL | NULL | 1 | Using join buffer (Block Nested Loop) |
  | 1 | SIMPLE | T1 | ALL | NULL | NULL | NULL | NULL | 1 | Using where; Using join buffer (Block Nested Loop) |
  | 1 | SIMPLE | T2 | ALL | NULL | NULL | NULL | NULL | 1 | Using where; Using join buffer (Block Nested Loop) |
  | 1 | SIMPLE | T3 | ALL | NULL | NULL | NULL | NULL | 1 | Using where; Using join buffer (Block Nested Loop) |
  | 1 | SIMPLE | t4 | ALL | NULL | NULL | NULL | NULL | 1 | Using where; Using join buffer (Block Nested Loop) |
  +----+-------------+-------+------+---------------+------+---------+------+------+----------------------------------------------------+
  7 rows in set (0.00 sec)
  如下输出,有价值的是“Duration”列,标示了一个Query的执行时间
  mysql> SHOW PROFILES;
  +----------+------------+-----------------------------------------------------------------------------------------------------------------------------
  ----------------------------------------------------------------------------------------------------+
  | Query_ID | Duration | Query
  |
  +----------+------------+-----------------------------------------------------------------------------------------------------------------------------
  ----------------------------------------------------------------------------------------------------+
  | 1 | 0.00274225 | EXPLAIN SELECT 1 FROM
  a
  LEFT JOIN b ON b.col = a.col
  RIGHT JOIN a AS T0 ON b.col = a.col
  LEFT JOIN a AS T1 ON T1.col = a.col
  RIGHT JOIN b AS T2 ON T2.col = a.col
  JOIN a AS T3 ON T3.col = a.col
  JOIN b AS t4 ON T4.col = a.col |
  +----------+------------+-----------------------------------------------------------------------------------------------------------------------------
  ----------------------------------------------------------------------------------------------------+
  1 row in set, 1 warning (0.00 sec)
  如下可以根据上条语句的输出信息中的“Query_ID”列的值,查询一条语句的具体情况
  
  mysql> SHOW PROFILE ALL FOR QUERY 1;
  +----------------------+----------+----------+------------+-------------------+---------------------+--------------+---------------+---------------+--
  -----------------+-------------------+-------------------+-------+-----------------+------------------+-------------+
  | Status               | Duration | CPU_user | CPU_system | Context_voluntary | Context_involuntary | Block_ops_in | Block_ops_out | Messages_sent | M
  essages_received | Page_faults_major | Page_faults_minor | Swaps | Source_function | Source_file      | Source_line |
  +----------------------+----------+----------+------------+-------------------+---------------------+--------------+---------------+---------------+--
  -----------------+-------------------+-------------------+-------+-----------------+------------------+-------------+
  | starting             | 0.000543 | 0.000000 |   0.000000 |              NULL |                NULL |         NULL |          NULL |          NULL |
  NULL |              NULL |              NULL |  NULL | NULL            | NULL             |        NULL |
  | checking permissions | 0.000018 | 0.000000 |   0.000000 |              NULL |                NULL |         NULL |          NULL |          NULL |
  NULL |              NULL |              NULL |  NULL |        | sql_parse.cc     |        5256 |
  | checking permissions | 0.000010 | 0.000000 |   0.000000 |              NULL |                NULL |         NULL |          NULL |          NULL |
  NULL |              NULL |              NULL |  NULL |        | sql_parse.cc     |        5256 |
  | checking permissions | 0.000009 | 0.000000 |   0.000000 |              NULL |                NULL |         NULL |          NULL |          NULL |
  NULL |              NULL |              NULL |  NULL |        | sql_parse.cc     |        5256 |
  | checking permissions | 0.000014 | 0.000000 |   0.000000 |              NULL |                NULL |         NULL |          NULL |          NULL |
  NULL |              NULL |              NULL |  NULL |        | sql_parse.cc     |        5256 |
  | checking permissions | 0.000016 | 0.000000 |   0.000000 |              NULL |                NULL |         NULL |          NULL |          NULL |
  NULL |              NULL |              NULL |  NULL |        | sql_parse.cc     |        5256 |
  | checking permissions | 0.000013 | 0.000000 |   0.000000 |              NULL |                NULL |         NULL |          NULL |          NULL |
  NULL |              NULL |              NULL |  NULL |        | sql_parse.cc     |        5256 |
  | checking permissions | 0.000018 | 0.000000 |   0.000000 |              NULL |                NULL |         NULL |          NULL |          NULL |
  NULL |              NULL |              NULL |  NULL |        | sql_parse.cc     |        5256 |
  | Opening tables       | 0.000259 | 0.000000 |   0.000000 |              NULL |                NULL |         NULL |          NULL |          NULL |
  NULL |              NULL |              NULL |  NULL |        | sql_base.cc      |        4911 |
  | init                 | 0.000212 | 0.000000 |   0.000000 |              NULL |                NULL |         NULL |          NULL |          NULL |
  NULL |              NULL |              NULL |  NULL |        | sql_select.cc    |        1050 |
  | System lock          | 0.000082 | 0.000000 |   0.000000 |              NULL |                NULL |         NULL |          NULL |          NULL |
  NULL |              NULL |              NULL |  NULL |        | lock.cc          |         304 |
  | optimizing           | 0.000149 | 0.000000 |   0.000000 |              NULL |                NULL |         NULL |          NULL |          NULL |
  NULL |              NULL |              NULL |  NULL |        | sql_optimizer.cc |         138 |
  | statistics           | 0.000280 | 0.000000 |   0.000000 |              NULL |                NULL |         NULL |          NULL |          NULL |
  NULL |              NULL |              NULL |  NULL |        | sql_optimizer.cc |         362 |
  | preparing            | 0.000121 | 0.000000 |   0.000000 |              NULL |                NULL |         NULL |          NULL |          NULL |
  NULL |              NULL |              NULL |  NULL |        | sql_optimizer.cc |         485 |
  | explaining           | 0.000423 | 0.000000 |   0.000000 |              NULL |                NULL |         NULL |          NULL |          NULL |
  NULL |              NULL |              NULL |  NULL |        | sql_select.cc    |         850 |
  | query end            | 0.000117 | 0.000000 |   0.000000 |              NULL |                NULL |         NULL |          NULL |          NULL |
  NULL |              NULL |              NULL |  NULL |        | sql_parse.cc     |        4956 |
  | closing tables       | 0.000121 | 0.000000 |   0.000000 |              NULL |                NULL |         NULL |          NULL |          NULL |
  NULL |              NULL |              NULL |  NULL |        | sql_parse.cc     |        5004 |
  | freeing items        | 0.000280 | 0.000000 |   0.000000 |              NULL |                NULL |         NULL |          NULL |          NULL |
  NULL |              NULL |              NULL |  NULL |        | sql_parse.cc     |        6264 |
  | cleaning up          | 0.000060 | 0.000000 |   0.000000 |              NULL |                NULL |         NULL |          NULL |          NULL |
  NULL |              NULL |              NULL |  NULL |        | sql_parse.cc     |        1774 |
  +----------------------+----------+----------+------------+-------------------+---------------------+--------------+---------------+---------------+--
  -----------------+-------------------+-------------------+-------+-----------------+------------------+-------------+
  19 rows in set, 1 warning (0.00 sec)
  五通过源码分析了解性能分析工具输出信息所表达的含义
  看这个简单运行结果,可以分析一条SQL语句执行的各个阶段的时间花费(根据源码分析得到的内容分析直接加在右侧):
  mysql> SHOW PROFILE FOR QUERY 1;
  +----------------------+----------+
  | Status               | Duration |
  +----------------------+----------+
  | starting             | 0.000543 |
  | checking permissions | 0.000018 |
  | checking permissions | 0.000010 |
  | checking permissions | 0.000009 |
  | checking permissions | 0.000014 |
  | checking permissions | 0.000016 |
  | checking permissions | 0.000013 |
  | checking permissions | 0.000018 |
  | Opening tables       | 0.000259 |
  | init                 | 0.000212 |
  | System lock          | 0.000082 |
  | optimizing           | 0.000149 |在JOIN::optimize()在函数中,大多数逻辑查询优化工作(如外连接消除/条件化简/)在这个阶段完成,如果这个时间花费多,则检查SQL进行逻辑查询优化调优工作
  | statistics           | 0.000280 |调用make_join_statistics()函数完成多表连接,主要执行的是物理查询优化,如果这个时间多,则多表连接的过程需要优化尤其注意要连接的表的个数较多的话,需要查看optimizer_search_depth的值,如果值很大,则需要修改其值为一个较小的数,如7
  | preparing            | 0.000121 |多表连接完成,准备其他一些优化操作,为调用JOIN::exec()作执行前的准备工作
  | explaining           | 0.000423 |
  | query end            | 0.000117 |
  | closing tables       | 0.000121 |
  | freeing items        | 0.000280 |
  | cleaning up          | 0.000060 |
  +----------------------+----------+
  19 rows in set, 1 warning (0.00 sec)
说明:  第一列,在代码中,通常都是调用如下类似语句完成:
  thd_proc_info(thd, "preparing");,对应的就是“| preparing | 0.000121 |”这一行的内容。



运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-625636-1-1.html 上篇帖子: PowerDesigner导入SQL生成数据模型 下篇帖子: Java执行上传的sql脚本文件
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表