【MySQL】MySQL5.7社区版如何开启metadata_locks

本文介绍如何在MySQL5.7社区版中开启metadata_locks,包括在线开启和重启服务后的持久化配置方法。通过更新performance_schema.setup_instruments表,可以启用特定的监控工具,从而能够查询全局读锁等信息。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

问题:
MySQL5.7社区版如何开启metadata_locks

参考:https://dev.mysql.com/doc/refman/5.7/en/performance-schema-quick-start.html
参考:https://dev.mysql.com/doc/refman/5.7/en/metadata-locks-table.html

performance_schema默认是启用的,但是默认只启用了部分工具(社区版MySQL5.7.28的performance_schema中目前共有1021个表)。

若要将全部工具和消费者开启,则操作如下:

mysql> UPDATE performance_schema.setup_instruments
       SET ENABLED = 'YES', TIMED = 'YES';
Query OK, 560 rows affected (0.04 sec)
mysql> UPDATE performance_schema.setup_consumers
       SET ENABLED = 'YES';
Query OK, 10 rows affected (0.00 sec)

若仅想在线开启metadata_locks,则操作如下:

--UPDATE performance_schema.setup_consumers SET ENABLED = 'YES' WHERE NAME ='global_instrumentation';
--此值默认已开启了,可检查确认。

UPDATE performance_schema.setup_instruments SET ENABLED = 'YES' WHERE NAME ='wait/lock/metadata/sql/mdl';

若可停库,则my.cnf中添加如下:

[mysqld]
performance-schema-instrument='wait/lock/metadata/sql/mdl=ON'

开启后用途:
如,可查询全局读锁(flush tables with read lock;)
用如下SQL查询:

select t.processlist_id from performance_schema.threads t join performance_schema.metadata_locks ml on ml.owner_thread_id = t.thread_id where ml.object_type='global' and ml.lock_type='shared';
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值