ROW模式下表无主键造成mysql从库延迟怎么处理
admin
2023-04-21 11:23:12
0

下文主要给大家带来ROW模式下表无主键造成mysql从库延迟怎么处理,希望这些内容能够带给大家实际用处,这也是我编辑ROW模式下表无主键造成mysql从库延迟怎么处理这篇文章的主要目的。好了,废话不多说,大家直接看下文吧。

场景:
MySQL-5.6.30, 主从架构,  只读从库的SQL线程卡在某一个事务两个多小时没有动过, show processlist发现从库当时没有连接和慢查询语句;
show open TABLES where In_use >0; 发现一个表被锁定如下:

mysql> show open TABLES where In_use >0;
+----------+---------------+--------+-------------+
| Database | Table         | In_use | Name_locked |
+----------+---------------+--------+-------------+
| cxx      | t_post_xxxxxx |      1 |           0 |
+----------+---------------+--------+-------------+

结论
从库没有线程,说明锁定的表是从主库同步过来的语句锁定的,应该是主库对此表的大事务操作造成。
分析
1.通过show slave status 确定的position去分析主库的binlog,发现生成了大量的删除 t_post_xxxxxx的语句;
2.查看慢查询日志,发现 delete from  t_post_xxxxxx;
3.在主库查看 t_post_xxxxxx表结构,发现竟然没有主键也没有索引;
4.select count(*) from  t_post_xxxxxx;发现此表20多万条数据;
5.真相大白了,没有主键直接delete删除全表会生成20多万条delete语句在binlog中,没有主键同步到从库需要执行20多万次全表扫描,20W*20W=400多亿,吓人!;
6.MySQL同步的时候, 会去利用主键来搜索需要修改的行(或者是一些二级索引)。
解决方案
1.增加主键;
2.跟研发沟通delete from t_post_xxxxxx改为truncate table t_post_xxxxxx。
综上
由于没有统一数据库上线平台和代码审核机制,造成一些不规范的代码以及数据库设计在生产运行。建议上线使用规范化的数据库上线平台,由平台自动发现数据库设计、数据库上线脚本问题,靠人肉上线难免会有疏漏,自动化运维势在必行,研发团队要使用代码规范检查工具避免不规范的代码上线。

对于以上关于ROW模式下表无主键造成mysql从库延迟怎么处理,大家是不是觉得非常有帮助。如果需要了解更多内容,请继续关注我们的行业资讯,相信你会喜欢上这些内容的。

相关内容

热门资讯

终于了解“新蛮王牛牛开挂器?”... 家人们!今天小编来为大家解答新蛮王牛牛透视挂怎么安装这个问题咨询软件客服徽9752949的挂在哪里买...
玩家最新攻略“新上游牛牛有没有... 您好:新上游牛牛这款游戏可以开挂,确实是有挂的,需要了解加客服微信【9752949】很多玩家在这款游...
我来教教您“人海牛牛开挂神器?... 您好:人海牛牛这款游戏可以开挂,确实是有挂的,需要了解加客服微信【9752949】很多玩家在这款游戏...
重磅消息“闽游麻将真的有挂吗?... 重磅消息“闽游麻将真的有挂吗?”(原来真的有挂)您好,闽游麻将这个游戏其实有挂的,确实是有挂的,需要...
今日重大通报“白金岛麻将圈有没... 您好:白金岛麻将圈这款游戏可以开挂,确实是有挂的,需要了解加客服微信【9752949】很多玩家在这款...
玩家最新攻略“TT语音真的有挂... 有 亲,根据资深记者爆料TT语音是可以开挂的,确实有挂(咨询软件无需打开...
今日重大发现“中至余干麻将是不... 有 亲,根据资深记者爆料中至余干麻将是可以开挂的,确实有挂(咨询软件无需...
终于明白“同城游跑胡子怎么装挂... 有 亲,根据资深记者爆料同城游跑胡子是可以开挂的,确实有挂(咨询软件无需...
今日重磅消息“新圣游牌九究竟有... 家人们!今天小编来为大家解答新圣游牌九透视挂怎么安装这个问题咨询软件客服徽4282891的挂在哪里买...
今日重磅消息“新广西老友麻将究... 网上科普关于“新广西老友麻将有没有挂”话题很是火热,小编也是针对新广西老友麻将作*弊开挂的方法以及开...