前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >MySQL数据库:使用show profile命令分析性能

MySQL数据库:使用show profile命令分析性能

作者头像
全栈程序员站长
发布2022-06-29 11:55:12
1.4K0
发布2022-06-29 11:55:12
举报
文章被收录于专栏:全栈程序员必看

1、show profile的作用:

能够查出最近执行的SQL语句的运行状态,包括在运行过程中执行了哪些操作,各占用了多少时间,利用proflie 功能,可以分析一个SQL具体的执行代价是怎么样的,尤其是可以分析它的最大瓶颈在哪里。目前profile 功能可提供除了内存以外的其他资源消耗统计,例如CPU、I/O、CONTEXT、SWAP等。大部分情况下,profile 的结果我们主要关注两列:Status、Duration,前者表示的是profile 里的状态,后者是该状态的耗时。因此,我们最主要的是关注处于哪个状态耗时最久,这些状态中,哪些是可以进一步优化的。

2、show profile 语法:

SHOW PROFILE [type [, type] … ] [FOR QUERY n] [LIMIT row_count [OFFSET offset]] type参数: | ALL:显示所有开销信息 | BLOCK IO:阻塞的输入输出次数 | CONTEXT SWITCHES:上下文切换相关开销信息 | CPU:显示CPU的相关开销信息 | IPC:接收和发送消息的相关开销信息 | MEMORY :显示内存相关的开销,目前无用 | PAGE FAULTS :显示页面错误相关开销信息 | SOURCE :列出相应操作对应的函数名及其在源码中的调用位置(行数) | SWAPS:显示swap交换次数的相关开销信息 LIMIT row_count子句用于限制输出行数。

3、show profile / show profiles的使用:

show profile 以及 show profiles语句可以显示当前会话过程中执行的sql语句的性能(profiling)信息。

(1)profiling功能由MySQL会话变量 : profiling控制,默认是OFF关闭状态,查看当前session是否开启profile功能:

select @@profiling; show variables like ‘profiling’;

(2)开启profiling:

set profiling=ON;

(3)运行SQL:

随便运行几条SQL,以便show profiles 的日志分析。

(4)查看结果:

(4.1)show profiles

show profiles 显示最近发给服务器的多条语句,条数根据会话变量profiling_history_size定义,默认是15,最大值为100。设为0等价于关闭profiling 分析功能。除SHOW PROFILE和SHOW PROFILES之外,所有sql语句的性能信息都会被记录,甚至包括有错误的语句。

show profiles;

MySQL数据库:使用show profile命令分析性能
MySQL数据库:使用show profile命令分析性能

(4.2)show profile

用于单独分析最近一条执行的sql语句的详细资源占用信息和工作状况,默认显示状态以及它们持续的时间。

show profile;

MySQL数据库:使用show profile命令分析性能
MySQL数据库:使用show profile命令分析性能

可以给show profile 指定一个 for query id 来查看指定 id 的语句,还可以给输出添加新的列。如,查看用户和CPU使用。可以用如下命令。(详细参数请看本文第2点的type参数)

show profile cpu,block io for query id;

id 为 show profiles 查出来的某条记录的Query_ID。

MySQL数据库:使用show profile命令分析性能
MySQL数据库:使用show profile命令分析性能

4、作用范围:

(1)这个命令只是在本会话内起作用,即无法分析本会话外的语句。开启分析功能后,所有本会话中的语句都被分析(甚至包括执行错误的语句),除了SHOW PROFILE和SHOW PROFILES两句本身。

(2)profiling是会话级的,当会话结束,与之相关的profiling信息也会随之消失。

(3)profiling是针对进程(process)而非线程(threads),因此运行在服务器上的其他服务进程可能会影响分析结果.

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/100070.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2021年4月9,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1、show profile的作用:
  • 2、show profile 语法:
  • 3、show profile / show profiles的使用:
  • 4、作用范围:
相关产品与服务
云数据库 MySQL
腾讯云数据库 MySQL(TencentDB for MySQL)为用户提供安全可靠,性能卓越、易于维护的企业级云数据库服务。其具备6大企业级特性,包括企业级定制内核、企业级高可用、企业级高可靠、企业级安全、企业级扩展以及企业级智能运维。通过使用腾讯云数据库 MySQL,可实现分钟级别的数据库部署、弹性扩展以及全自动化的运维管理,不仅经济实惠,而且稳定可靠,易于运维。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档