返回顶部
首页 > 资讯 > 数据库 >MySQL怎么快速定位慢SQL
  • 283
分享到

MySQL怎么快速定位慢SQL

2023-06-29 14:06:16 283人浏览 安东尼
摘要

本文小编为大家详细介绍“MySQL怎么快速定位慢sql”,内容详细,步骤清晰,细节处理妥当,希望这篇“Mysql怎么快速定位慢SQL”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。开启慢查询日志在项目中我们会经常遇

本文小编为大家详细介绍“MySQL怎么快速定位慢sql”,内容详细,步骤清晰,细节处理妥当,希望这篇“Mysql怎么快速定位慢SQL”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。

开启慢查询日志

项目中我们会经常遇到慢查询,当我们遇到慢查询的时候一般都要开启慢查询日志,并且分析慢查询日志,找到慢sql,然后用explain来分析

系统变量

mysql和慢查询相关的系统变量如下

参数含义
slow_query_log是否启用慢查询日志, ON为启用,OFF为没有启用,默认为OFF
log_output日志输出位置,默认为FILE,即保存为文件,若设置为TABLE,则将日志记录到mysql.show_log表中,支持设置多种格式
slow_query_log_file指定慢查询日志文件的路径和名字
long_query_time执行时间超过该值才记录到慢查询日志,单位为秒,默认为10

执行如下语句看是否启用慢查询日志,ON为启用,OFF为没有启用

show variables like "%slow_query_log%"

MySQL怎么快速定位慢SQL

可以看到我的没有启用,可以通过如下两种方式开启慢查询

修改配置文件

修改配置文件my.ini,在[mysqld]段落中加入如下参数

[mysqld]log_output='FILE,TABLE'slow_query_log='ON'long_query_time=0.001

需要重启 MySQL 才可以生效,命令为 service mysqld restart

设置全局变量

我在命令行中执行如下2句打开慢查询日志,设置超时时间为0.001s,并且将日志记录到文件以及mysql.slow_log表中

set global slow_query_log = on;set global log_output = 'FILE,TABLE';set global long_query_time = 0.001;

想要永久生效得到配置文件中配置,否则数据库重启后,这些配置失效

分析慢查询日志

因为mysql慢查询日志相当于是一个流水账,并没有汇总统计的功能,所以我们需要用一些工具来分析一下

mysqldumpslow

mysql内置了mysqldumpslow这个工具来帮我们分析慢查询日志。

MySQL怎么快速定位慢SQL

常见用法

# 取出使用最多的10条慢查询mysqldumpslow -s c -t 10 /var/run/mysqld/mysqld-slow.log# 取出查询时间最慢的3条慢查询mysqldumpslow -s t -t 3 /var/run/mysqld/mysqld-slow.log # 得到按照时间排序的前10条里面含有左连接的查询语句mysqldumpslow -s t -t 10 -g “left join” /database/mysql/slow-log

pt-query-digest

pt-query-digest是我用的最多的一个工具,功能非常强大,可以分析binlog、General log、slowlog,也可以通过show processlist或者通过tcpdump抓取的MySQL协议数据来进行分析。pt-query-digest是一个perl脚本,只需下载并赋权即可执行

下载和赋权

wget www.percona.com/get/pt-query-digestchmod u+x pt-query-digestln -s /opt/soft/pt-query-digest /usr/bin/pt-query-digest

用法介绍

// 查看具体使用方法 pt-query-digest --help// 使用格式pt-query-digest [OPTioNS] [FILES] [DSN]

常用OPTIONS

  • --create-review-table  当使用--review参数把分析结果输出到表中时,如果没有表就自动创建。

  • --create-history-table  当使用--history参数把分析结果输出到表中时,如果没有表就自动创建。

  • --filter  对输入的慢查询按指定的字符串进行匹配过滤后再进行分析

  • --limit限制输出结果百分比或数量,默认值是20,即将最慢的20条语句输出,如果是50%则按总响应时间占比从大到小排序,输出到总和达到50%位置截止。

  • --host  mysql服务器地址

  • --user  mysql用户名

  • --passWord  mysql用户密码

  • --history 将分析结果保存到表中,分析结果比较详细,下次再使用--history时,如果存在相同的语句,且查询所在的时间区间和历史表中的不同,则会记录到数据表中,可以通过查询同一CHECKSUM来比较某类型查询的历史变化。

  • --review 将分析结果保存到表中,这个分析只是对查询条件进行参数化,一个类型的查询一条记录,比较简单。当下次使用--review时,如果存在相同的语句分析,就不会记录到数据表中。

  • --output 分析结果输出类型,值可以是report(标准分析报告)、slowlog(Mysql slow log)、JSONjson-anon,一般使用report,以便于阅读。

  • --since 从什么时间开始分析,值为字符串,可以是指定的某个”yyyy-mm-dd [hh:mm:ss]”格式的时间点,也可以是简单的一个时间值:s(秒)、h(小时)、m(分钟)、d(天),如12h就表示从12小时前开始统计。

  • --until 截止时间,配合—since可以分析一段时间内的慢查询。

常用DSN

A    指定字符集
D    指定连接的数据库
P    连接数据库端口
S    连接Socket file
h    连接数据库主机名
p    连接数据库的密码
t    使用--review或--history时把数据存储到哪张表里
u    连接数据库用户名

DSN使用key=value的形式配置;多个DSN使用,分隔

使用示例

# 展示slow.log中最慢的查询的报表pt-query-digest slow.log# 分析最近12小时内的查询pt-query-digest --since=12h slow.log# 分析指定范围内的查询pt-query-digest slow.log --since '2020-06-20 00:00:00' --until '2020-06-25 00:00:00'# 把slow.log中查询保存到query_history表pt-query-digest --user=root --password=root123 --review h=localhost,D=test,t=query_history --create-review-table slow.log# 连上localhost,并读取processlist,输出到slowlogpt-query-digest --processlist h=localhost --user=root --password=root123 --interval=0.01 --output slowlog# 利用tcpdump获取MySQL协议数据,然后产生最慢查询的报表# tcpdump使用说明:https://blog.csdn.net/chinaltx/article/details/87469933tcpdump -s 65535 -x -nn -q -tttt -i any -c 1000 port 3306 > mysql.tcp.txtpt-query-digest --type tcpdump mysql.tcp.txt# 分析binlogmysqlbinlog mysql-bin.000093 > mysql-bin000093.sqlpt-query-digest  --type=binlog mysql-bin000093.sql# 分析general logpt-query-digest  --type=genlog  localhost.log

用法实战

编写存储过程批量造数据

在实际工作中没有测试性能,我们经常需要改造大批量的数据,手动插入是不太可能的,这时候就得用到存储过程了

CREATE TABLE `kf_user_info` (  `id` int(11) NOT NULL COMMENT '用户id',  `gid` int(11) NOT NULL COMMENT '客服组id',  `name` varchar(25) NOT NULL COMMENT '客服名字') ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='客户信息表';

如何定义一个存储过程呢?

CREATE PROCEDURE 存储过程名称 ([参数列表])BEGIN    需要执行的语句END

举个例子,插入id为1-100000的100000条数据

用Navicat执行

-- 删除之前定义的DROP PROCEDURE IF EXISTS create_kf;-- 开始定义CREATE PROCEDURE create_kf(IN loop_times INT) BEGINDECLARE var INT;SET var = 1;WHILE var < loop_times DO    INSERT INTO kf_user_info (`id`,`gid`,`name`) VALUES (var, 1000, var);SET var = var + 1;END WHILE; END;-- 调用call create_kf(100000);

存储过程的三种参数类型

参数类型是否返回作用
IN向存储过程传入参数,存储过程中修改该参数的值,不能被返回
OUT把存储过程计算的结果放到该参数中,调用者可以得到返回值
INOUTIN和OUT的结合,即用于存储过程的传入参数,同时又可以把计算结构放到参数中,调用者可以得到返回值

用MySQL执行

得用DELIMITER 定义新的结束符,因为默认情况下SQL采用(;)作为结束符,这样当存储过程中的每一句SQL结束之后,采用(;)作为结束符,就相当于告诉MySQL可以执行这一句了。但是存储过程是一个整体,我们不希望SQL逐条执行,而是采用存储过程整段执行的方式,因此我们就需要定义新的DELIMITER ,新的结束符可以用(//)或者($$)

因为上面的代码应该就改为如下这种方式

DELIMITER //CREATE PROCEDURE create_kf_kfGroup(IN loop_times INT)  BEGIN  DECLARE var INT;SET var = 1;WHILE var <= loop_times DO    INSERT INTO kf_user_info (`id`,`gid`,`name`) VALUES (var, 1000, var);SET var = var + 1;END WHILE;  END //DELIMITER ;

查询已经定义的存储过程

show procedure status;

开始执行慢sql

select * from kf_user_info where id = 9999;select * from kf_user_info where id = 99999;update kf_user_info set gid = 2000 where id = 8888;update kf_user_info set gid = 2000 where id = 88888;

可以执行如下sql查看慢sql的相关信息。

SELECT * FROM mysql.slow_log order by start_time desc;

查看一下慢日志存储位置

show variables like "slow_query_log_file"
pt-query-digest /var/lib/mysql/VM-0-14-Centos-slow.log

执行后的文件如下

MySQL怎么快速定位慢SQL

# Profile# Rank Query ID                            Response time Calls R/Call V/M # ==== =================================== ============= ===== ====== ====#    1 0xE2566F6154AFF41948FE497E53631B43   0.1480 56.1%     4 0.0370  0.00 UPDATE kf_user_info#    2 0x2DFBC6DBF0D68EF2EC2AE954DC37A1A4   0.1109 42.1%     4 0.0277  0.00 SELECT kf_user_info# MISC 0xMISC                               0.0047  1.8%     2 0.0024   0.0 <2 ITEMS>

从最上面的统计sql中就可以看到执行慢的sql

可以看到响应时间,执行次数,每次执行耗时(单位秒),执行的sql

下面就是各个慢sql的详细分析,比如,执行时间,获取的时间,执行时间分布,所在的表等信息

不由得感叹一声,真是神器,查看慢sql超级方便

最后说一个我遇到的一个有意思的问题,有一段时间线上的接口特别慢,但是我查日志发现sql执行的很快,难道是网络的问题?

为了确定是否是网络的问题,我就用拦截器看了一下接口的执行时间,发现耗时很长,考虑到方法加了事务,难道是事务提交很慢?

于是我用pt-query-digest统计了一下1分钟左右的慢日志,发现事务提交的次很多,但是每次提交事务的平均时长是1.4s左右,果然是事务提交很慢。

MySQL怎么快速定位慢SQL

读到这里,这篇“MySQL怎么快速定位慢SQL”文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注编程网数据库频道。

您可能感兴趣的文档:

--结束END--

本文标题: MySQL怎么快速定位慢SQL

本文链接: https://lsjlt.com/news/325370.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • MySQL怎么快速定位慢SQL
    本文小编为大家详细介绍“MySQL怎么快速定位慢SQL”,内容详细,步骤清晰,细节处理妥当,希望这篇“MySQL怎么快速定位慢SQL”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。开启慢查询日志在项目中我们会经常遇...
    99+
    2023-06-29
  • MySQL如何快速定位慢SQL的实战
    目录开启慢查询日志系统变量修改配置文件设置全局变量分析慢查询日志mysqldumpslowpt-query-digest开启慢查询日志 在项目中我们会经常遇到慢查询,当我们遇到慢查询...
    99+
    2024-04-02
  • MySQL怎么定位慢SQL
    这篇文章主要讲解了“MySQL怎么定位慢SQL”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“MySQL怎么定位慢SQL”吧! &...
    99+
    2024-04-02
  • MySQL实战记录之如何快速定位慢SQL
    目录开启慢查询日志系统变量修改配置文件设置全局变量分析慢查询日志mysqldumpslowpt-query-digest用法实战总结开启慢查询日志 在项目中我们会经常遇到慢查询,当我...
    99+
    2024-04-02
  • MySQL中怎么定位慢查询
    本篇文章给大家分享的是有关MySQL中怎么定位慢查询,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。NO.1 慢查询日志定位解析MySQL 的慢...
    99+
    2024-04-02
  • mysql5.7怎么快速定位IO瓶颈
    这篇文章将为大家详细讲解有关mysql5.7怎么快速定位IO瓶颈,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。背景环境1. MySQL 5.7&nbs...
    99+
    2024-04-02
  • MySQL-如何定位慢查询SQL以及优化
    如何定位慢查询SQL以及优化 慢查询日志记录慢SQLexplain查看分析SQL执行计划profile分析执行耗时Optimizer Trace分析详情确定问题采用响应措施 慢查询日志记录...
    99+
    2023-09-12
    sql 数据库 java
  • MySQL5.6怎么快速定位不合理索引
    这篇文章主要讲解了“MySQL5.6怎么快速定位不合理索引”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“MySQL5.6怎么快速定位不合理索引”吧! ...
    99+
    2024-04-02
  • mysql怎么快速导入sql文件
    你可以使用以下命令快速导入一个SQL文件到MySQL数据库中:```mysql -u username -p database_na...
    99+
    2023-09-20
    mysql
  • MySQL定位并优化慢查询sql的方法是什么
    本篇内容介绍了“MySQL定位并优化慢查询sql的方法是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!1.如何定位并优化慢查询sql  ...
    99+
    2023-06-22
  • MySQL定位并优化慢查询sql的详细实例
    目录1.如何定位并优化慢查询sql   a.根据慢日志定位慢查询sqlb.使用explain等工具分析sqlc.修改sql或者尽量让sql走索引2.联合索引的最左匹配原则的成因简单说...
    99+
    2024-04-02
  • mysql 简单定位慢查询并分析SQL执行效率
    实际的日常开发工作中可能会遇到某个新功能在测试时需要很久才返回结果,这时就应该分析是不是慢查询导致的,如果确实有慢查询,就需要来学习怎么找到慢查询和怎么分析 SQL 执行效率? 定位慢 SQL 有如下两种解决方案: 查看慢查询日志确定已经执...
    99+
    2023-09-14
    dba sql mysql
  • 解析Discuz!7.0快速定位功能
    关键字描述:Discuz 康盛创想 Comsenz 公司 建站产品 论坛 BBS 站长   Discuz!7.0是康盛创想(Comsenz)公司于2008年12月份发布的一款论坛BBS建站产品。Discuz!7.0.0...
    99+
    2022-06-12
    定位 功能 快速 解析 后台 站长 设置 Discuz 可以 7.0.0
  • 【Mysql】快速定位不合理的索引——MySQL索引调优(一)
    原文地址:http://mp.weixin.qq.com/s__biz=MjM5MjIxNDA4NA==&mid=401131835&idx=1&sn=37c5fd9d3d8670f...
    99+
    2024-04-02
  • MySQL慢查询如何定位详解
    前言 相信大家在平时工作中都有过 SQL 优化经历,那么在优化前就必须找到慢 SQL 方可进行分析。这篇文章就介绍下如何定位到慢查询。 慢查询日志是 MySQL 内置的一项功能,可以记录执行超过指定时间的 SQL 语...
    99+
    2022-05-17
    mysql 慢查询分析 mysql慢查询定位 mysql开启慢查询
  • 如何快速定位Oracle锁表原因?
    如何快速定位Oracle锁表原因? 在Oracle数据库中,当出现锁表现象时,会影响系统的性能并导致操作阻塞,因此及时定位锁表原因是非常重要的。本文将介绍如何快速定位Oracle锁表原...
    99+
    2024-03-11
    oracle 定位 锁表 sql语句
  • MySQL的慢SQL怎么优化
    本篇内容主要讲解“MySQL的慢SQL怎么优化”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“MySQL的慢SQL怎么优化”吧!索引类似大学图书馆建书目索引,可以...
    99+
    2024-04-02
  • sql server卡慢问题定位与排查过程
    目录一、数据库服务器资源排查二、数据库sql性能排查2.1、查询哪些资源被阻塞了 和 堵进程2.2、查询spid/BlkBy 阻塞进程语句2.3、查看指定数据库的锁id进行2.4、杀进程三、查询sql语句执行时间和sql...
    99+
    2023-03-06
    sqlserver数据库卡慢分析 sqlserver数据库卡顿 sqlserver突然特别慢
  • sql server卡慢问题定位与排查过程
    目录一、数据库服务器资源排查二、数据库sql性能排查2.1、查询哪些资源被阻塞了 和 堵进程2.2、查询spid/BlkBy 阻塞进程语句2.3、查看指定数据库的锁id进行2.4、杀...
    99+
    2023-03-06
    sqlserver数据库卡慢分析 sqlserver数据库卡顿 sqlserver突然特别慢
  • 使用find命令快速定位配置文件位置
    大家知道在配置的时候咱们经常需要修改配置文件,甚至现在的开发就是配配配,记又记不住,每次自己查找太费时间,最近学会了一个命令-find,现在分享以下,当然他能做的不止于此接下来以nginx为例子,那么问题来了nginx中...
    99+
    2022-12-08
    find命令定位配置文件位置 find命令定位文件位置 find命令查找文件
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作