如何识别MySQL中哪个事务导致'等待表元数据锁”状态?

Patricia Arquette
发布: 2024-10-31 02:12:30
原创
126 人浏览过

How to Identify Which Transaction is Causing the “Waiting for Table Metadata Lock” State in MySQL?

识别导致“等待表元数据锁定”状态的事务

在 MySQL 版本 5.5.24 中尝试对表进行 DDL 操作但遇到“等待表元数据锁定”消息,确定负责此锁定的事务变得至关重要。

解决方案

适用于 5.7.3 以下的 MySQL 版本:

执行以下命令以检索有关状态的详细信息:

SHOW ENGINE INNODB STATUS \G
登录后复制

找到“TRANSACTIONS”部分并识别尚未关闭的开放交易。

对于所有 MySQL 版本:

从 INFORMATION_SCHEMA 表中检索信息:

所有等待锁:

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

阻止事务:

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

SELECT INNODB_LOCKS.* FROM INNODB_LOCKS JOIN INNODB_LOCK_WAITS ON (INNODB_LOCKS.LOCK_TRX_ID = INNODB_LOCK_WAITS.BLOCKING_TRX_ID);
登录后复制

锁定特定表:

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

等待事务:

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

请参阅 MySQL 故障排除:查询不起作用时该怎么办,第 6 章,第 96 页以获取更多见解.

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

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责声明 Sitemap
PHP中文网:公益在线PHP培训,帮助PHP学习者快速成长!