mysql添加索引导致《Waiting for table metadata lock》

论坛 期权论坛 脚本     
匿名技术用户   2021-1-3 08:55   11   0

1.背景

今天收到线上数据库慢查询报警,对用户造成了严重影响。需要快速处理恢复正常运行。这应该算是一次严重的线上事故。

2.mysql中show processlist 出现大量的 Waiting for table metadata lock

首先需要定位原因。

3.大概原因:对electric_invoice这个表上添加了联合索引。但是这个表有未提交的事物。添加索引属于ddl操作,会等待事务完成。事务迟迟未完成。当该表处于《Waiting for table metadata lock》状态,将阻塞其他任何操作,包含读。所以设计该表的sql查询是慢查询。长达几百几千秒。

该问题参考https://www.cnblogs.com/digdeep/p/4892953.html

分享到 :
0 人收藏
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

积分:7942463
帖子:1588486
精华:0
期权论坛 期权论坛
发布
内容

下载期权论坛手机APP