Mysql调优之Profiling


一、引出Profiling

显然我们在评价一条SQL语句的好坏时最直观的评价指标就是它执行时长了。那我们要如何得知一条SQL语句的执行时间呢?Mysql5.0之后的版本提供了Query Profiler 功能,它不仅可以计算出每一条Query的执行时间,并且它还可以显示这条Query的性能问题,例如执行这条SQL消耗了到少CPU、IO等资源,以便于我们针对性的对其进行性能调优。

二、Profiling如何使用

1.开启Profiling

Profiling默认是关闭状态,我们先来查看一下此功能有没有开启:

  1. 登录mysql
mysql -uroot -p 
  1. 输入密码后,进到mysql里,输入如下语句查询profiling状态,可以看到默认值为OFF。
mysql> show variables like 'profiling';
+---------------+-------+
| Variable_name | Value |
+---------------+-------+
| profiling     | OFF   |
+---------------+-------+
1 row in set, 9 warnings (0.00 sec)
  1. 开启profiling,关闭的话设置为0即可。
mysql> set profiling=1

2.Profiling使用

现在我们就可以来使用Profiling了。在开启profiling功能后,MySQL就会自动记录所有执行的 Query 的 profile 信息。

mysql> show profiles;

获取系统中所有Query的profile信息(默认显示最近15条,Query_ID依次递增)
在这里插入图片描述
其中Query_ID是SQL语句的ID编号,Duration是这条SQL语句的执行时长,Query是具体的SQL语句。
重点来了:我们还可以通过show profile [参数1] for query [Query_ID]来查看指定ID的SQL语句的详细资源消耗情况。
参数1为可选类型值,具体如下:

  • ALL显示所有信息
  • BLOCK IO显示块输入和输出操作的计数
  • CONTEXT SWITCHES显示自愿和非自愿上下文切换的计数
  • CPU显示用户和系统 CPU 使用时间
  • IPC显示发送和接收的消息计数
  • MEMORY当前未实现
  • PAGE FAULTS显示主要和次要页面错误的计数
  • SOURCE显示源代码中的函数名称,以及发生函数的文件的名称和行号
  • SWAPS显示交换计数
show profile cpu,block io for query [Query_ID];

在这里插入图片描述

三、实际应用场景

在开发阶段,出现慢SQL,我们可以先通过explain语句查看该SQL的执行情况;
例如,这里准备了一张表test_user,想要查询地区(region_id)为64的user_name:

explain select user_name from test_user WHERE region_id = 64;

在这里插入图片描述
看这条语句有没有走索引(key),我这显然是没有的,没有的话需要建立合适的索引;
如果已经走索引,可以通过show profile来进一步排查。

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值