微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

MySQL Waiting for table metadata lock的解决方法

最近需要在某一个表中新增字段,使用Sequel Pro 或者Navicat工具都会出现程序没有反应,使用 show processlist 查看,满屏都是 Waiting for table Metadata lock 状态的连接,第一反应当然是 kill 掉这些链接,但是假如太多怎么办?遂在找寻其他办法。

在网上查询得知MysqL在进行一些alter table等DDL操作时,如果该表上有未提交的事务则会出现 Waiting for table Metadata lock ,而一旦出现Metadata lock,该表上的后续操作都会被阻塞(http://www.bubuko.com/infodetail-1151112.html)。所以这个问题需从两方面解决

1. 查看未提交事务


information_schema.innodb_trx 表中查看当前未提交的事务

select trx_state,trx_started,trx_MysqL_thread_id,trx_query from information_schema.innodb_trx;

字段意义:

trx_state: 事务状态,一般为RUNNING
trx_started: 事务执行的起始时间,若时间较长,则要分析该事务是否合理
trx_MysqL_thread_id: MysqL的线程ID,用于kill
trx_query: 事务中的sql

一般只要kill掉这些线程,DDL操作就不会Waiting for table Metadata lock。

2. 调整锁超时阈值
lock_wait_timeout 表示获取Metadata lock的超时(单位秒),允许的值范围为1到31536000(1年)。 认值为31536000 (1年)。官方解释:https://dev.mysql.com/doc/refman/5.6/en/server-system-variables.html#sysvar_lock_wait_timeout 。

修改等待时间:

set session lock_wait_timeout = 1800;
set global lock_wait_timeout = 1800;

经过以上操作,我司的数据库暂时还未出现情况,有相同经历的不妨试一试,如果有更好的解决方案,欢迎留言!!

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐