MySQL慢查询分析与处理

什么是慢日志

慢日志是MySQL用来记录数据库中执行较慢的SQL语句的日志,当数据库遇到性能问题时,慢日志可以帮助我们分析数据库中执行较慢的SQL。

如何打开数据库慢日志功能

MySQL默认是关闭慢日志功能的,可以从数据库中或者从配置文件中进行修改。

在数据库中临时开启:

set global slow_query_log = 'on'; //开启慢查询日志

set global slow_query_log_file = 'path/mysql_xx_slow.log';//设置慢日志路径

set global long_query_time = 2;//设置慢查询阈值,单位秒,超过阈值的SQL会记录到慢日志

配置文件(my.cnf)中永久开启:

slow_query_log = 1

slow_query_log_file = path/mysql_xx_slow.log

long_query_time = 2

log_queries_not_using_indexes = 1 -- 可选项:记录那些没有使用索引的查询

慢日志内容格式

Time: 2023-10-12T09:14:23.563457Z

User@Host: user[user] @ localhost []

Query_time: 12.345678 Lock_time: 0.000123 Rows_sent: 10 Rows_examined: 1000

Rows_affected: 0 Bytes_sent: 512

SET timestamp=1634038463;

SELECT * FROM large_table WHERE column = 'value';

  • Time:查询的执行时间。
  • User@Host:发起查询的用户和主机。
  • Query_time:查询执行的时间,单位为秒。
  • Lock_time:查询执行期间的锁定时间。
  • Rows_sent:查询返回的行数。
  • Rows_examined:查询过程中检查的行数。
  • Rows_affected :影响的行数(如 INSERTUPDATEDELETE 等)。
  • Bytes_sent:返回的数据大小(以字节为单位)。
  • SET timestamp:查询执行的时间戳。
  • SQL 语句:执行的具体 SQL 查询。

如何快速分析很大的慢日志

使用PerconaToolkit中的pt-query-digest工具可以帮助我们快速分析MySQL的慢查询日志。

相关推荐
阿蒙Amon1 小时前
C# Linq to SQL:数据库编程的解决方案
数据库·c#·linq
互联网搬砖老肖5 小时前
运维打铁: MongoDB 数据库集群搭建与管理
运维·数据库·mongodb
典学长编程6 小时前
数据库Oracle从入门到精通!第四天(并发、锁、视图)
数据库·oracle
积跬步,慕至千里6 小时前
clickhouse数据库表和doris数据库表迁移starrocks数据库时建表注意事项总结
数据库·clickhouse
极限实验室7 小时前
搭建持久化的 INFINI Console 与 Easysearch 容器环境
数据库
星辰离彬7 小时前
Java 与 MySQL 性能优化:Java应用中MySQL慢SQL诊断与优化实战
java·后端·sql·mysql·性能优化
白仑色7 小时前
Oracle PL/SQL 编程基础详解(从块结构到游标操作)
数据库·oracle·数据库开发·存储过程·plsql编程
程序猿小D9 小时前
[附源码+数据库+毕业论文]基于Spring+MyBatis+MySQL+Maven+jsp实现的个人财务管理系统,推荐!
java·数据库·mysql·spring·毕业论文·ssm框架·个人财务管理系统
钢铁男儿10 小时前
C# 接口(什么是接口)
java·数据库·c#
__风__10 小时前
PostgreSQL kv(jsonb)存储
数据库·postgresql