首页 > 数据库 > mysql教程 > 如何识别MySQL中导致'等待表元数据锁”的罪魁祸首事务?

如何识别MySQL中导致'等待表元数据锁”的罪魁祸首事务?

Linda Hamilton
发布: 2024-10-30 17:23:25
原创
968 人浏览过

How to Identify the Culprit Transaction Causing

调查“Waiting for Table Metadata Lock”的来源

在MySQL中,在DDL时遇到“Waiting for table Metadata Lock”消息查询可能会令人沮丧。此状态通常表明另一个事务正在受影响的表上持有锁,从而阻止当前事务继续进行。

识别罪魁祸首事务

查明哪个事务是负责此保留,请考虑使用以下方法:

1。 MySQL v5.5.24 及以下

对于 5.7.3 之前的 MySQL 版本,执行以下命令:

SHOW ENGINE INNODB STATUS \G
登录后复制

检查“TRANSACTIONS”部分以识别有问题的事务。

2。信息模式表

所有等待锁:

SELECT * FROM INFORMATION_SCHEMA.INNODB_LOCK_WAITS;
登录后复制

阻塞事务:

SELECT *
FROM INFORMATION_SCHEMA.INNODB_LOCKS
WHERE LOCK_TRX_ID IN (SELECT BLOCKING_TRX_ID FROM INFORMATION_SCHEMA.INNODB_LOCK_WAITS);
登录后复制

特定表上的锁定:

SELECT *
FROM INFORMATION_SCHEMA.INNODB_LOCKS
WHERE LOCK_TABLE = db_name.table_name;
登录后复制

等待锁定的事务:

SELECT TRX_ID, TRX_MYSQL_THREAD_ID, TRX_QUERY
FROM INFORMATION_SCHEMA.INNODB_TRX
WHERE TRX_STATE = 'LOCK WAIT';
登录后复制

其他参考:

有关解决此问题的综合指南,请参阅“MySQL 故障排除:查询不起作用时该怎么办”,第 6 章,第 96 页。

以上是如何识别MySQL中导致'等待表元数据锁”的罪魁祸首事务?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板