当前位置: 首页 > news >正文

MySQL中insert阻塞问题的分析

这是学习笔记的第 2262 篇文章

读完需要

9

分钟

速读仅需7分钟

今天收到一个业务报警,提示某个数据库实例的连接数暴涨,然后瞬间又恢复了,这种情况持续反复了几次,和开发同学沟通时,他们也希望能够得到更多的信息,比如是哪个数据库的连接数异常暴涨,我也想知道啊,但是苦于没有合适的工具和方法能够实现更细粒度的监控/统计,于是我着手开始分析这个问题。

这是一套MySQL 5.7.16的环境,事务隔离级别为RR

等我连接到这套环境的时候,show processlist的输出已经恢复了正常,查看相关的数据库日志也没有任何额外的输出,查看慢日志发现了有一部分的慢日志,提示是在insert into的语句,看起来着实蹊跷,计。

# User@Host: testdb[testdb] @  [xxxx.xx3]
# Query_time: 3.461818  Lock_time: 0.000067 Rows_sent: 0  Rows_examined: 0
SET timestamp=1597826800;
INSERT INTO `device_confignew_clientup` (`device_type`, `device_model`, `chipset_model`, `manufacturer`, `score`, `match_type`, `physic_memory`, `created_on`, `updated_on`, `is_open`) VALUES ('4', 'JEF-AN00', 'Hisilicon Kirin985', 'HUAWEI', '3000', '0', '7503', '1597826797', '1597826797', '1');

一条insert语句怎么会执行3秒多,往前继续翻,有些甚至都达到了10多秒,

在没有更多日志支撑的前提下,根据负载情况,我在主库打开了general log查看整个实例的操作明细,可以看到如下的日志信息,我截取了一段比较有代表性的日志。

首先,根据行首的id可以看到线程id增长会快,目前已经是4000万左右了,根据线程的连接情况可以看到,整个业务操作是基于短连接的形式处理的。

同时整个操作中涉及的表也很明显,是device_confignew_clientup,和慢日志里面显示的表和信息是可以互相呼应的。

表device_confignew_clientup的结构如下:

CREATE TABLE `device_confignew_clientup` (
  `id` int(11) unsigned NOT NULL AUTO_INCREMENT COMMENT '主键',
  `device_model` varchar(200) NOT NULL DEFAULT '' ,
  `device_match` varchar(200) NOT NULL DEFAULT '' ,
  `score` int(11) unsigned NOT NULL DEFAULT '0' ,
  `chipset_model` varchar(200) NOT NULL DEFAULT '' ,
  `manufacturer` varchar(100) NOT NULL DEFAULT '' ,
 ....
  PRIMARY KEY (`id`),
  UNIQUE KEY `uniq_dm_ma` (`device_model`,`manufacturer`,`chipset_model`) USING BTREE
) ENGINE=InnoDB AUTO_INCREMENT=50160457 DEFAULT CHARSET=utf8 ;

结合这些信息,我们似乎可以找到问题的突破口,那就是里面的那个唯一性索引。按照这个约束,主键值id是从SQL里面自增完成的,唯一性索引基于3个字段,如果仔细观察上面的日志就户发现,基于同样的列值,竟然在日志里面两个不同的客户端发起了同样的SQL.

顺着这个思路,我继续进行排查,发现问题是越来越清晰了,我基于一个字段开始梳理,发现这个编码的数据相关的Insert有5000多条,也就意味着这个业务里面存在着大量冗余的数据写入。

grep -B4 JXX-AN00 general.log |wc -l
5295

整个业务和数据库的数据链路如下:

业务服务器会不断发起短连接请求,整个过程中是无状态的,发起的数据写入很可能是冗余的,为了在数据库中达到唯一性,设置了这个唯一性索引,而业务的持续不断的写入,因为唯一性索引会额外有检测数据库冲突的逻辑,所以相关的SQL都会阻塞,积累起来就会发现是1/N的写入命中率。

从这一点也可以看出,很多业务对于分布式应用的理解还是有限,应用服务器水平扩展就不考虑整个链路里面的数据一致性和唯一性了,导致数据库最后成了瓶颈,况且在这个层面的ACID代价其实就很高了。

而和业务的沟通来看,他们后续会做一些修正:

1)将短连接模式修改为长连接模式

2)在业务层进行数据操作时,先进行数据探测,如果已经存在则不做后续的处理,否则写入

3)对于应用分布式架构中对于数据库唯一性校验和数据一致性方面进行更进一步的测试,从设计理念上需要做一些转变。

QQ群号:763628645

QQ群二维码如下, 添加请注明:姓名+地区+职位,否则不予通过

订阅我的微信公众号“杨建荣的学习笔记”,第一时间免费收到文章更新。别忘了加星标,以免错过新推送提示。

   

近期热文

你可能也会对以下话题感兴趣。点击链接就可以查看。

相关文章:

  • MySQL数据延迟跳动的问题分析
  • 彻底取代Redis+数据库架构,京东618稳了!
  • 一个扭蛋的故事
  • 做一次完美的数据迁移
  • 招贤纳士-第16期,来自北京和成都的职位
  • MySQL安装部署,从半成品状态的改进
  • 从SQL Server到TiDB的架构设计及对数据中台的思考
  • 近期的状态小结和最近要做的一些事情
  • 一次完整的JVM堆外内存泄漏故障排查记录
  • 35岁老码农:老板,你看我还有机会吗?
  • 打算搞一个简单的开源项目mysql_lite
  • 打开黑盒:从 MySQL 架构设计出发,看它是如何执行一条 SQL 语句的?
  • 手把手教你用 Jenkins + K8S 打造流水线环境
  • 命运与决择,我的十五年IT路
  • MySQL代码开发和调试利器CLion
  • avalon2.2的VM生成过程
  • iOS | NSProxy
  • iOS编译提示和导航提示
  • Java面向对象及其三大特征
  • java正则表式的使用
  • JDK 6和JDK 7中的substring()方法
  • Linux快速配置 VIM 实现语法高亮 补全 缩进等功能
  • PHP变量
  • puppeteer stop redirect 的正确姿势及 net::ERR_FAILED 的解决
  • REST架构的思考
  • 爱情 北京女病人
  • 搞机器学习要哪些技能
  • 技术发展面试
  • 入职第二天:使用koa搭建node server是种怎样的体验
  • 双管齐下,VMware的容器新战略
  • 王永庆:技术创新改变教育未来
  • 验证码识别技术——15分钟带你突破各种复杂不定长验证码
  • 选择阿里云数据库HBase版十大理由
  • ​软考-高级-系统架构设计师教程(清华第2版)【第12章 信息系统架构设计理论与实践(P420~465)-思维导图】​
  • # Python csv、xlsx、json、二进制(MP3) 文件读写基本使用
  • #define,static,const,三种常量的区别
  • #define与typedef区别
  • #在线报价接单​再坚持一下 明天是真的周六.出现货 实单来谈
  • (¥1011)-(一千零一拾一元整)输出
  • (12)Hive调优——count distinct去重优化
  • (cos^2 X)的定积分,求积分 ∫sin^2(x) dx
  • (分享)自己整理的一些简单awk实用语句
  • (深入.Net平台的软件系统分层开发).第一章.上机练习.20170424
  • (四) 虚拟摄像头vivi体验
  • (一)eclipse Dynamic web project 工程目录以及文件路径问题
  • (转载)Linux 多线程条件变量同步
  • . NET自动找可写目录
  • .htaccess配置常用技巧
  • .NET I/O 学习笔记:对文件和目录进行解压缩操作
  • .NET Micro Framework 4.2 beta 源码探析
  • .NET MVC、 WebAPI、 WebService【ws】、NVVM、WCF、Remoting
  • .NET 的静态构造函数是否线程安全?答案是肯定的!
  • .NET使用存储过程实现对数据库的增删改查
  • @media screen 针对不同移动设备
  • @Transactional 详解