慢SQL筛查

开启慢SQL日志

#开启慢SQL日志功能
SET GLOBAL slow_query_log=ON;
#慢SQL执行时间阈值设置,单位:秒
SET GLOBAL long_query_time=3;
#指定慢SQL文件名为slow-sql,慢SQL日志保存在mysql/data目录下
SET GLOBAL slow_query_log_file='/var/lib/mysql/slow-sql.log';
#是否记录没有使用索引的SQL语句
SET GLOBAL log_queries_not_using_indexes=ON;

#查看配置项(my.cnf)
SHOW VARIABLES LIKE '%quer%'

#日志文件格式如下
# Time: 2021-10-18T06:09:45.527133Z --执行时间
# User@Host: root[root] @ DESKTOP-IOHEJFM.superzig.com [10.0.0.138]  Id:    14 --环境信息
# Query_time: 0.000413  --查询时间
# Lock_time: 0.000093 --资源锁定时间
# Rows_sent: 10  --查询结果总行数
# Rows_examined: 499 --扫描行数
#SET timestamp=1634537385; --时间戳
# ==SQL语句==
#SELECT  id,is_deleted,gmt_create,gmt_modified,operator_id,specification_name,document_path,code,version,status,military_specification_name  FROM optable_process_specification 
#WHERE is_deleted = 0 ORDER BY gmt_create DESC LIMIT 10;

分析慢SQL日志

# mysql内置了mysqldumpslow这个工具来帮我们分析慢查询日志
# 这个是命令,在linux输入的,不是mysql里面
# 取出使用最多的10条慢查询
mysqldumpslow -s c -t 10 /var/lib/mysql/slow-sql.log

# 取出查询时间最慢的3条慢查询
mysqldumpslow -s t -t 3 /var/lib/mysql/slow-sql.log 

# 得到按照时间排序的前10条里面含有左连接的查询语句
mysqldumpslow -s t -t 10 -g “left join” /var/lib/mysql/slow-sql.log 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值