`

MySQL SQL Tuning:Profile定位单条QUERY性能瓶颈

 
阅读更多

当生了病的query来就诊时,如果身为医生的我们"胡庸医乱用虎狼药"
不仅于事无补,还浪费了大量的人力和时间成本,甚至会拖垮服务器
所以,我们在接受优化一条SQL,第一件事情便是要明白query病在哪里?
是IO?是CPU?只有明白瓶颈在哪里,方可对症下药,也才能药到病除
而MySQL QUERY Profiler是一个使用非常方便的QUERY诊断工具,5.0引入。5.1GA版嵌入
这个工具详细呈现了SQL在整个生命周期的每个动作,这和Oracle开启1046事件类似
我们可以很清晰地明白该SQL是在数据存取还是运算(排序或分组等)上花费得多
那么我们就不会很盲目地看到order by就去tuning sort buffer而忽略sorting result时间是如此之少

Profile语法:

  1. SHOW PROFILE [type [, type] ... ]  
  2.     [FOR QUERY n]  
  3.     [LIMIT row_count [OFFSET offset]]  
  4.   
  5. type:  
  6.     ALL  
  7.   | BLOCK IO  
  8.   | CONTEXT SWITCHES  
  9.   | CPU  
  10.   | IPC  
  11.   | MEMORY  
  12.   | PAGE FAULTS  
  13.   | SOURCE  
  14.   | SWAPS  

注解:
默认输出结果只会展示Status和Duration,我们可以指定type来扩展输出
我比较常用的是外加CPU和BLOCK IO来输出CPU和IO的负载,其实这些已经够了

默认profile是关闭的,通过profiling参数控制,为session级
开启:SET profiling=1
关闭:set profiling=0
查询:select @@profiling 
show profiles保存的query条数由参数profiling_history_size控制,默认是15,超过了会把前面的剔掉

  1. mysql> set profiling=1;  
  2.   
  3. mysql> select @@profiling;  
  4. +-------------+  
  5. | @@profiling |  
  6. +-------------+  
  7. |           1 |  
  8. +-------------+  
  9.   
  10. mysql> select * from employees.t order by first_name;  
  11.   
  12. mysql> show profiles;  
  13. +----------+------------+-----------------------------------------------+  
  14. | Query_ID | Duration   | Query                                         |  
  15. +----------+------------+-----------------------------------------------+  
  16. |        1 | 0.21138800 | show create table employees.t                 |  
  17. |        2 | 8.21691600 | select * from employees.t order by first_name |  
  18. +----------+------------+-----------------------------------------------+  
  19. 2 rows in set (0.00 sec)  
  20.   
  21. mysql> show profile cpu,block io for query 2;  
  22. +----------------------+----------+----------+------------+--------------+---------------+  
  23. | Status               | Duration | CPU_user | CPU_system | Block_ops_in | Block_ops_out |  
  24. +----------------------+----------+----------+------------+--------------+---------------+  
  25. | starting             | 0.000160 | 0.000000 |   0.000000 |            0 |             0 |  
  26. | checking permissions | 0.000026 | 0.000000 |   0.000000 |            0 |             0 |  
  27. | Opening tables       | 0.000055 | 0.000000 |   0.000000 |            0 |             0 |  
  28. | System lock          | 0.000033 | 0.000000 |   0.000000 |            0 |             0 |  
  29. | init                 | 0.000050 | 0.000000 |   0.000000 |            0 |             0 |  
  30. | optimizing           | 0.000026 | 0.000000 |   0.000000 |            0 |             0 |  
  31. | statistics           | 0.000145 | 0.000000 |   0.000000 |            0 |             0 |  
  32. | preparing            | 0.000118 | 0.000000 |   0.000000 |            0 |             0 |  
  33. | executing            | 0.000011 | 0.000000 |   0.000000 |            0 |             0 |  
  34. | Sorting result       | 2.838465 | 1.396087 |   1.140071 |            0 |             0 |  
  35. | Sending data         | 0.928078 | 0.544034 |   0.056003 |            0 |             0 |  
  36. | end                  | 0.000026 | 0.000000 |   0.000000 |            0 |             0 |  
  37. | query end            | 0.000011 | 0.000000 |   0.000000 |            0 |             0 |  
  38. | closing tables       | 0.000021 | 0.000000 |   0.000000 |            0 |             0 |  
  39. | freeing items        | 4.449672 | 0.000000 |   0.000000 |            0 |             0 |  
  40. | logging slow query   | 0.000014 | 0.000000 |   0.000000 |            0 |             0 |  
  41. | cleaning up          | 0.000005 | 0.000000 |   0.000000 |            0 |             0 |  
  42. +----------------------+----------+----------+------------+--------------+---------------+  
  43. 17 rows in set (0.00 sec)  

相同的信息我们还可以从information_schema里面输出,并且我们还可以对时间进行排序
因为Profile默认是按执行顺序排序的,而实际上我们更关心的是花费了多少时间,这才能方便知道哪些开销较大

  1. mysql> SELECT STATE, FORMAT(DURATION, 6) AS DURATION  
  2.     -> FROM INFORMATION_SCHEMA.PROFILING  
  3.     -> WHERE QUERY_ID = 2 ORDER BY DURATION DESC;  
  4. +----------------------+----------+  
  5. | STATE                | DURATION |  
  6. +----------------------+----------+  
  7. | freeing items        | 4.449672 |  
  8. | Sorting result       | 2.838465 |  
  9. | Sending data         | 0.928078 |  
  10. | starting             | 0.000160 |  
  11. | statistics           | 0.000145 |  
  12. | preparing            | 0.000118 |  
  13. | Opening tables       | 0.000055 |  
  14. | init                 | 0.000050 |  
  15. | System lock          | 0.000033 |  
  16. | end                  | 0.000026 |  
  17. | optimizing           | 0.000026 |  
  18. | checking permissions | 0.000026 |  
  19. | closing tables       | 0.000021 |  
  20. | logging slow query   | 0.000014 |  
  21. | query end            | 0.000011 |  
  22. | executing            | 0.000011 |  
  23. | cleaning up          | 0.000005 |  
  24. +----------------------+----------+  
  25. 17 rows in set (0.00 sec)  
分享到:
评论

相关推荐

    SQL Tuning Advisor使用总结

    本文详细介绍了如何使用SQL Tuning Advisor进行SQL语句的性能优化,涵盖了从AWR报告、游标缓存及SQL Tuning Set中获取SQL语句并建立、执行调优任务的方法。通过遵循上述步骤,可以显著提高数据库的运行效率和响应...

    SQL Tuning sqlServer 数据库

    《SQL Tuning in sqlServer 数据库》是一本专注于优化SQL Server数据库性能的专业教程,以英文的CHM(Compiled HTML Help)格式提供。SQL优化是数据库管理中的关键环节,它直接影响到系统的响应速度和整体性能。以下...

    SQL Server 2017 Query Performance Tuning Fifh Edition

    这本书深入探讨了SQL Server的性能调优技术,涵盖了从诊断性能瓶颈到实施高效查询策略的广泛主题。 在SQL Server的环境中,查询性能调优是提升系统效率的关键步骤。它涉及到多个方面,包括查询设计、索引管理、查询...

    sqltuning 英文版

    《SQL Tuning》英文版是一本专注于数据库性能优化的专业书籍,尤其关注SQL查询的调整与优化。SQL(Structured Query Language)是用于管理关系数据库的标准语言,它的效率和正确性直接影响到数据库系统的整体性能。...

    Oracle 12C SQL Tuning for Developers

    2. **自动SQL调优**:Oracle 12C引入了Automatic SQL Tuning,它自动识别性能瓶颈并提出优化建议。通过Advisor工具,如SQL Tuning Advisor,系统会分析SQL语句并提供改进建议,如创建索引、重写查询或调整绑定变量。...

    oracle sqltuning workshop

    在这个"Oracle SQLTuning Workshop"中,虽然资料可能源自2004年,但它依然包含了许多至今仍具价值的基础知识和实践经验。以下是一些核心知识点的详细说明: 1. **SQL基础**:SQL(结构化查询语言)是用于管理和处理...

    oracle sql_tuning

    12. **SQL优化顾问**:Oracle提供内置的SQL优化工具,如SQL Tuning Advisor和Automatic Workload Repository (AWR),它们能分析SQL性能并提供改进建议。 13. **物化视图**:对于固定的复杂查询,创建物化视图可以...

    自动SQL优化工具Tosska SQL Tuning Expert for Oracle 64位

    1. **智能分析**:该工具能够自动分析SQL语句的执行计划,识别性能瓶颈,如全表扫描、排序操作过多、不合理的连接方式等。 2. **性能建议**:基于分析结果,提供改进建议,比如建议创建或修改索引、调整SQL语句结构...

    Oracle SQL Tuning with Oracle SQLTXPLAIN: Oracle Database 12c Edition

    Oracle SQL Tuning with Oracle SQLTXPLAIN: Oracle Database 12c Edition by Stelios Charalambides English | 8 May 2017 | ISBN: 1484224353 | 408 Pages | PDF | 24.39 MB Learn through this practical guide ...

    Tosska SQL Tuning Expert for Oracle 1.5.0_x64.exe

    1. **性能瓶颈排查**:当系统运行缓慢,或特定查询响应时间过长时,Tosska SQL Tuning Expert可迅速找出问题所在。 2. **数据库维护**:定期使用该工具对SQL语句进行检查,预防潜在的性能问题。 3. **新项目上线**...

    Top-SQL Tuning SQL语句调整

    标题与描述中的“Top-SQL Tuning SQL语句调整”主要聚焦于提升SQL查询的效率与性能,这是数据库管理与优化的重要组成部分。SQL语句的性能直接影响到应用程序的响应时间和系统的整体性能,因此,掌握有效的SQL调优...

    Tosska SQL Tuning Expert for Oracle

    Tosska SQL Tuning Expert for Oracle提供了全面且深入的SQL分析功能,帮助用户快速定位并解决性能瓶颈。这款工具的核心特性包括: 1. **智能诊断**:该工具能够自动识别低效的SQL语句,通过复杂的算法分析,给出...

    Inside SQL Server 2005: Query Tuning and Optimization

    Inside SQL Server 2005: Query Tuning and Optimization <br>不用多说,Kalen Delaney 关于Inside SQL Server 2005的第四卷(查询调校和最优化)

    SQL Server 2017 Query Performance Tuning

    本篇将重点探讨"SQL Server 2017 Query Performance Tuning"的相关知识点。 1. **查询优化器**:SQL Server 2017的查询优化器是决定查询执行计划的关键组件。它通过分析可能的执行路径,选择最有效率的方式来执行...

    Db10g SQL Tuning Vol-I

    SQL Tuning 是指优化 SQL 语句以提高查询性能的过程。在 Db10g 中,SQL Tuning 的重点在于通过调整 SQL 语句或配置参数来提高查询速度,减少资源消耗。 ### 二、SQL Tuning 的重要性 在现代企业环境中,数据库性能...

    MySQL Performance Tuning Active Guide MySQL Performance Tuning

    "MySQL Performance Tuning Active Guide" 是一份旨在帮助用户提升MySQL数据库性能的指南,主要面向正在使用或计划优化MySQL性能的专业人士。 本指南可能涵盖以下关键知识点: 1. **SQL查询优化**:包括查询分析,...

    SQL Server 2008 Query Performance Tuning Distilled

    《SQL Server 2008 Query Performance Tuning Distilled》是一本专为数据库管理员、开发者和技术人员编写的指南书籍,旨在帮助他们理解和掌握SQL Server 2008中的查询性能优化技术。本书由Grant Fritchey和Sajal Dam...

    Tosska SQL Tuning Expert for Oracle 2.0.3_x64.exe

    Tosska SQL Tuning Expert (TSE™) 是一款优秀的SQL 调优工具,无需用户参与即可优化 SQL 语句。该产品将为您提供最终的 SQL 性能解决方案,只需点击鼠标即可。在整个 SQL 调优过程中,您不必进行分析、猜测或手工...

Global site tag (gtag.js) - Google Analytics