mysql 案例 ~ insert插入慢的场景

一简介: insert出现慢日志中,应该怎么检测呢

二 理解:事务提交延迟,一般出现在写日志延迟的情况下,会有几种可能
    场景:
    1 RR模式下,insert等待gap lock锁导致的
    2 insert等待MDL锁导致
    3 表存在外键约束,耗时在外键检测上
    4 表没有主键

    5 表中含有blob/text和大varchar这种大字段
    6 半同步复制的延迟导致插入延迟等待
    7 DB服务器IO压力较大,导致排队,iowait很高 
          1 并发insert的线程较多
          2 并发select的线程较多
    8 磁盘空间不足导致插入延迟等待

    9  优化task慢sql,因为慢sql同样会抢占你的IO/CPU资源
三 案例:
   1 描述:线上慢日志定期会出现insert慢日志,大概1s左右,非常奇怪
   2 排查思路:
       1 慢日志除了insert语句,并没有大表扫描的慢查询->排查慢查询的干扰
       2 观察binlog生成量,非常少,尝试调整sync_binlog参数,并没效果->排查binlog刷新的干扰
       3 尝试调整innodb_flush_commit参数,并没有效果->排查redo刷新的干扰

       4 查看innodb_buffer_pool的命中率,查看脏页刷新频率效果
       5 观察慢日志insert发生时间,大多发生在整点和半点,查看对应的qps图,发现对应的select并发非常高,找到了原因
   3 解决方案: 进行读写分离拆分,进一步进行观察

posted @   开心的蛋黄派  阅读(6211)  评论(0编辑  收藏  举报
编辑推荐:
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
阅读排行:
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
点击右上角即可分享
微信分享提示