MySQL#秘籍#一条SQL语句执行时间以及资源分析

背景

一条 SQL 语句的执行完,每个模块耗时,不同资源(CPU/IO/IPC/SWAP)消耗情况我该如何知道呢?别慌俺有 - MySQL profiling

1. SQL语句执行前 - 开启profiling
sql 复制代码
-- profiling (0-关闭 1-开启)
-- 或者:show variables like 'profiling';
mysql> select @@profiling;

-- 开启
mysql> SET profiling = 1;
-- 关闭
mysql> SET profiling = 0;
2. 执行某个SQL语句
3. 执行分析

3.1 显示当前会话产生的所有profiles

mysql> show profiles;

说明:每次最多显示最近15条profiles

Query_ID: 每条SQL语句ID编号

Duration:SQL语句执行时长

Query:具体的SQL语句

3.2 查看最近一条SQL执行情况

mysql> show profile;
3.3 查看指定query id的执行情况

mysql> show profile for query xxx_query_id;

  1. Status: 显示了SQL执行的一个完整的生命周期,涉及到各个阶段。
  2. Duration: 表示SQL在这个阶段的耗时。

3.4 执行资源(CPU/IO/IPC/SWAP)分析

mysql> show profile CPU, BLOCK IO for query xxx_query_id;

说明:show profile不指定type时默认只显示 StatusDuration

ALL:显示所有的开销信息。

BLOCK IO:显示块存储设备输入和输出的次数,即从硬盘读取和写入数据的次数。只有当数据量大于内存可用量时,才会借助硬盘进行内存交换(Swap),才会产生硬盘读取和写入。

CONTEXT SWITCHES:上下文切换开销。

CPU:显示CPU开销信息。

IPC:显示发送和接收开销信息。

MEMORY:显示内存开销信息。

PAGE FAULTS:显示页面错误开销信息。

SOURCE:显示和Source_function,Source_file, Source_line相关的开销信息。

SWAPS:显示交换次数开销信息。
注意事项:

  1. profile统计的数据依赖于底层system call调用,某些操作系统上不支持调用时值会返回NULL
  2. profiling统计的信息是进程级别而非线程级别,统计信息时刻在变更。
  3. Profiling信息还可以通过INFORMATION_SCHEMA PROFILING table 查询
    SELECT STATE, FORMAT(DURATION, 6) AS DURATION FROM INFORMATION_SCHEMA.PROFILING WHERE QUERY_ID = 2 ORDER BY SEQ;
  4. 从profiling分析结果Status中得到优化方向
    • converting HEAP to MyISAM: 查询结果太大,内存不够用
    • Creating tmp table: 创建临时表。先拷贝数据到临时表,用完后再删除临时表
    • Copying to tmp table on disk: 把内存中临时表复制到磁盘上
    • locked: 发生了死锁行为
复制代码
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
}

参考文档

https://dev.mysql.com/doc/refman/8.0/en/show-profile.html

profiling Statue : https://dev.mysql.com/doc/refman/8.0/en/general-thread-states.html

相关推荐
掘根6 小时前
【MySQL集群架构与实践5】使用Docker实现水平分片
mysql·docker·架构
爬山算法7 小时前
MySQL(173)MySQL中的存储过程和函数有什么区别?
数据库·mysql
Ruimin05197 小时前
Mysql集群技术
数据库·mysql
果冻kk11 小时前
MySQL MVCC:并发神器背后的原理解析
数据库·mysql
喜欢敲代码的程序员12 小时前
SpringBoot+Mybatis+MySQL+Vue+ElementUI前后端分离版:日志管理(四)集成Spring Security
spring boot·mysql·spring·vue·mybatis
Fireworkitte13 小时前
SQL 中 CASE WHEN 及 SELECT CASE WHEN 的用法
数据库·sql·mysql
叁沐16 小时前
MySQL 24 MySQL是怎么保证主备一致的?
mysql
Cyber4K18 小时前
MySQL--组从复制的详解及功能演练
运维·数据库·mysql·云原生
MMMMMMMMMMemory19 小时前
使用 MySQL Shell 进行 MySQL 单机到 InnoDB Cluster 的数据迁移实践
mysql
啊森要自信20 小时前
【MySQL 数据库】MySQL索引特性(二)页目录&&(B和B+树)&&(非)聚簇索引 && 索引操作
android·数据库·sql·mysql·adb·数据库架构