mysql语句性能分析工具之profiling用法

 更新时间:2023年12月13日 15:36:54   作者:zyjzyjjyzjyz  
这篇文章主要介绍了mysql语句性能分析工具之profiling用法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

以往我们已经介绍了一个mysql的分析工具:mysql慢查询日志分析工具(pt-query-digest),可以看我的文章:mysql慢查询日志分析工具(pt-query-digest)

一、profiling的介绍

sql查询慢的情况很常见,对于慢sql的优化有三个步骤,又称优化三板斧。

  • 板斧一:查看执行计划explain
  • 板斧二:建立合适索引
  • 板斧三:使用合适的连接关系和过滤条件来实现sql语句的优化

如果执行计划正确sql语句的性能还很慢,可以通过mysql的profiling工具进行定位分析。

为了更精准的定位一条sql语句的性能问题,需要清楚的直到这条sql语句运行时消耗多少系统资源。

mysql中profiling工具可以满足此需求,通过该工具可以获取一条sql语句在执行过程中多种资源的消耗情况——比如cpu,io,ipc,swap等资源消耗情况。

二、profiling使用方法

2.1、启用命令

set profiling = 1;

2.2、启动命令后,运行想要查询性能的sql语句

select * from xiatui where name like '0%' and age = '9803' and sex =0;

2.3、查询上述sql语句信息

show profiles;

 说明:

  • Query_ID:sql语句的id编号,这个编号会在步骤4、5用到
  • Duration:sql语句执行时长
  • Query:具体的sql语句

2.4、查询资源消耗情况

SHOW PROFILE CPU, BLOCK IO FOR QUERY 360;

上述360就是第三步骤的Query_ID值,想要查询哪条sql语句,就输入哪条sql语句对应的id值。

2.5、查询某条sql语句的具体执行时间

SHOW PROFILE FOR QUERY 391;

优化建议:

如果想要优化某条sql语句,可以关注一下该条sql语句的show profile结果中每个阶段的耗时,分析耗时最长的阶段。

如果status列出现下面的信息就可以考虑对sql语句进行优化:

  • converting heap to  MyISAM:查询结果太大,内存不够用
  • creating tmp table:创建了临时表。先拷贝数据到临时表,用完后再删除临时表。
  • copying to tmp table on disk:把内存中临时表复制到磁盘上
  • locked:发生了死锁行为。                

2.6、关闭

set profiling = 0;

三、整体使用过程

set profiling = 1;
select /*+ no_icp(xiatui) */ * from xiatui where name like '0%' and age = '9803' and sex =0;
select * from xiatui where name like '0%' and age = '9803' and sex =0;
show profiles;
set profiling = 0;

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • MySQL使用binlog日志进行数据库迁移和数据恢复

    MySQL使用binlog日志进行数据库迁移和数据恢复

    MySQL的二进制日志是MySQL数据库中非常关键的一个组件,主要用于记录所有数据库表结构或表数据改变的操作语句,binlog是MySQL数据复制的基础,并且常常被用于数据恢复,本文给大家介绍了MySQL使用binlog日志进行数据库迁移和数据恢复,需要的朋友可以参考下
    2024-04-04
  • MySQL数据库21条最佳性能优化经验

    MySQL数据库21条最佳性能优化经验

    数据库的操作越来越成为整个应用的性能瓶颈了,这点对于Web应用尤其明显。这篇文章主要介绍了MySQL数据库21条最佳性能优化经验的相关资料,需要的朋友可以参考下
    2016-10-10
  • MySQL8.0实现窗口函数计算同比环比

    MySQL8.0实现窗口函数计算同比环比

    本文主要介绍了MySQL8.0实现窗口函数计算同比环比,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-06-06
  • MySQL的一些常用的SQL语句整理

    MySQL的一些常用的SQL语句整理

    这篇文章主要介绍了MySQL的一些常用的SQL语句整理,非常基础,适合随看随记:)需要的朋友可以参考下
    2015-07-07
  • linux下指定mysql数据库服务器主从同步的配置实例

    linux下指定mysql数据库服务器主从同步的配置实例

    linux下指定数据库服务器主从同步的配置实例,有需要的朋友可以参考下
    2013-01-01
  • MYSQL SERVER收缩日志文件实现方法

    MYSQL SERVER收缩日志文件实现方法

    这篇文章主要介绍了MYSQL SERVER收缩日志文件实现方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-08-08
  • MySQL常见故障与优化方式

    MySQL常见故障与优化方式

    这篇文章主要介绍了MySQL常见故障与优化方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教<BR>
    2024-04-04
  • MySQL中NULL对索引的影响深入讲解

    MySQL中NULL对索引的影响深入讲解

    这篇文章主要给大家介绍了关于MySQL中NULL对索引的影响的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用MySQL具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-07-07
  • MySQL自增ID用完的几种解决方案

    MySQL自增ID用完的几种解决方案

    MySQL的自增ID(AUTO_INCREMENT)用完之后,会出现重复ID的问题,那么如何解决这个问题呢,接下本文就给大家介绍MySQL自增ID用完的几种解决方案,需要的朋友可以参考下
    2023-07-07
  • 找到MySQL的优点

    找到MySQL的优点

    假设你是一个Access开发人员,而你想移植一个Access后台到一个本地的MySQL 服务器用于开发和测试。你将维护你自己的解决方案并乐于使用Community Server
    2009-09-09

最新评论