MySQL--慢查询日志、日志分析工具mysqldumpslow

mysqldumpslow 常用参数:

复制代码
-s,是order的顺序

----- al 平均锁定时间

-----ar 平均返回记录时间

-----at 平均查询时间(默认)

-----c 计数

-----l 锁定时间

-----r 返回记录

-----t 查询时间

-t,是top n的意思,即为返回前面多少条的数据

-g,后边可以写一个正则匹配模式,大小写不敏感的

# 取出使用最多的10条慢查询
mysqldumpslow -s c -t 10 /data/mysql/bogon-slow.log
 
# 取出查询时间最慢的3条慢查询 
mysqldumpslow -s t -t 3 /data/mysql/bogon-slow.log
 
# 得到按照时间排序的前10条里面含有左连接的查询语句 
mysqldumpslow -s t -t 10 -g "left join" /data/mysql/bogon-slow.log
 
# 按照扫描行数最多的
mysqldumpslow -s r -t 10 -g 'left join' /data/mysql/bogon-slow.log

# 筛选出insert语句
mysqldumpslow -s r -t 10 -g 'insert' /data/mysql/bogon-slow.log

排查数据库插入操作

重点排查插入操作的激增原因,可以从以下几个方面着手:

a. 查看插入语句的执行日志
  • 检查 MySQL 的 查询日志 (如果开启了),尤其是 INSERT 语句的执行情况。通过分析哪些表或哪些业务操作频繁执行插入操作,可以帮助定位问题的根源。

  • 如果没有开启查询日志,可以临时启用:

    SET global general_log = 1;
    SET global log_output = 'TABLE'; -- 或者 'FILE'

然后查询执行日志:

复制代码
#没加时间段过滤
SELECT * FROM mysql.general_log WHERE command_type='Query' AND argument LIKE 'INSERT%';

#加具体时间段过滤
SELECT * FROM mysql.general_log WHERE (command_type = 'Query' AND argument LIKE 'INSERT%' AND event_time BETWEEN '2025-06-09 14:12:00' AND '2025-06-09 14:14:00');

general_log具体包含哪些字段:

复制代码
DESCRIBE mysql.general_log;

这将显示 mysql.general_log 表的所有列及其数据类型,帮助你了解每个字段的含义。通常,general_log 表包括以下一些常见字段:

  • event_time:记录查询的时间。

  • user_host:执行查询的用户和主机。

  • thread_id:执行查询的线程 ID。

  • server_id:服务器 ID。

  • command_type :执行的命令类型(如 QueryConnectQuit 等)。

  • argument:执行的 SQL 查询或命令的内容。

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