Mysql 慢查询

慢查询的定义及作用

慢查询日志,就是查询慢的日志,是指mysql 记录所有执行超过 long_query_time 参数设定的时间阈值的sql 语句的日志,该日志能为 SQL 语句的优化带来很好的帮助。默认情况下是关闭的,要使用慢查询日志,首先需要开启日志功能。

慢查询的配置
常用配置:
  • slow_query_log 启动停止慢查询日志
set GLOBAL slow_query_log =1
  • slow_query_log_file 指定慢查询日志的存储路径及文件(默认和数据文件放一起)

  • long_query_time 指定记录慢查询日志 SQL 执行事件的阈值 (单位:秒 默认10秒)

  • log_queries_not_using_indexes 是否记录未使用索引的 SQL

  • log_output 日志存放的地方 table,file.table and file

慢查询日志记录符合条件的 sql
  • 查询语句
  • 数据修改语句
  • 已经回滚的 SQL
慢查询分析:

在这里插入图片描述

结果说明:
行号内容
1用户名,用户的IP信息,线程ID号
2执行花费的时间(单位:毫秒)
3执行获得锁的时间
4获得的结果行数
5扫描的数据行数
6这条SQL执行的具体时间
7具体的SQL语句
慢查询分析工具
mysqldumpslow(mysql自带)

常用的慢查询日志分析工具,汇总除查询条件外其他完全相同的sql,并将分析结果按照参数中所指定的顺序输出。

语法:

mysqldumpslow -s r -t 10 slow-mysql.log
  • -s order (c,t,l,r,at,al,ar)

    c : 总次数

    t: 总时间

    l: 锁的时间

    r: 总数据行

    at,al,ar : t,l,r (例如:at = 总时间/总次数)

  • -t top 指定取前面几条作为结果输出。

安装目录及其用法 :
在这里插入图片描述
在这里插入图片描述
缺点:需要登录客户端才能访问。必须有权限等,并且无法显示执行计划

pt_query_digest

命令:

pt-query-digest  --explain h=127.0.0.1, u=root,p=password slow-mysql.log

在这里插入图片描述
列名的含义:总的查询时间,总的锁定时间,总的获取数据量,扫描的数据量,查询大小

在这里插入图片描述
response : 总的响应时间。

time: 该查询在本次分析中总的时间占比。

calls: 执行次数,即本次分支在总有多少条这种类型的查询语句

R/call: 平均每次执行的响应时间

Item: 查询对象。

学习年限不足,知识过浅,说的不对请见谅。

世界上有10种人,一种是懂二进制的,一种是不懂二进制的。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值