Metadata Lock在MySQL数据库中有什么作用
admin
2023-04-19 09:43:38
0

下文主要给大家带来Metadata Lock在MySQL数据库中有什么作用,希望这些内容能够带给大家实际用处,这也是我编辑Metadata Lock在MySQL数据库中有什么作用这篇文章的主要目的。好了,废话不多说,大家直接看下文吧。

在主库上truncate table后,发现从库延时开始增加,show processlist可见如下信息。


72105289  system user  NULL  Connect 2996302 Waiting for master to send event  NULL  0  0

72105290  system user  dbname  Connect 491  Waiting for table metadata lock truncate table tblname  0  0


MySQL用metadata lock控制对于数据库对象的并发访问,和保证数据的一致性。MySQL中不能对一个正在使用的表执行DDL语句,就是通过获取表的metadata lock实现的,其阻止了表结构的变更。即,若表正被一个事务使用,在该事务结束前,另一个会话是不能对此表执行DDL的。


Waiting for table metadata lock,表明在truncate table之前已有事务在使用tblname表了,且该事务还没结束,从show processlist中看不到进一步的信息了。


但information_schema中的innodb_trx表可以提供正在InnoDB中运行着的事务的信息,如事务是否在等待锁、事务的开始时间、事务中正在运行的SQL等。


查看innodb_trx表,发现了一个事务,Id为90916563(trx_mysql_thread_id对应show processlist中的Id),开始时间是2019-02-12 13:26:56,在主库执行truncate table的时间是17:35,其运行的时间有些异常;另trx_query为NULL,可判断该事务很可能卡在这,未正常结束,阻止了truncate table的继续。


mysql> select * from INNODB_TRX \G

*************************** 1. row ***************************

                    trx_id: 146633268809

                 trx_state: RUNNING

               trx_started: 2019-02-12 13:26:56

     trx_requested_lock_id: NULL

          trx_wait_started: NULL

                trx_weight: 0

       trx_mysql_thread_id: 90916563

                 trx_query: NULL

       trx_operation_state: NULL

         trx_tables_in_use: 0

         trx_tables_locked: 0

          trx_lock_structs: 0

     trx_lock_memory_bytes: 1136

           trx_rows_locked: 0

         trx_rows_modified: 0

   trx_concurrency_tickets: 0

       trx_isolation_level: REPEATABLE READ

         trx_unique_checks: 1

    trx_foreign_key_checks: 1

trx_last_foreign_key_error: NULL

 trx_adaptive_hash_latched: 0

 trx_adaptive_hash_timeout: 0

          trx_is_read_only: 0

trx_autocommit_non_locking: 0

1 row in set (0.00 sec)


从show processlist中看到Id为90916563线程的信息,其Time为1294。kill掉该线程,主从复制恢复正常。

90916563  dbname_read  192.168.2.36:63063  dbname  Sleep  1294  NULL  100  100


若想查看metadata lock的详细信息,可借助Performance Schema下的metadata_locks表。

对于以上关于Metadata Lock在MySQL数据库中有什么作用,大家是不是觉得非常有帮助。如果需要了解更多内容,请继续关注我们的行业资讯,相信你会喜欢上这些内容的。

相关内容

热门资讯

今日重大消息“道游联盟到底有挂... 您好:道游联盟这款游戏可以开挂,确实是有挂的,需要了解加客服微信【9752949】很多玩家在这款游戏...
金源智能取得电池焊接压装装置专... 国家知识产权局信息显示,惠州金源智能机器人有限公司取得一项名为“电池焊接压装装置及焊接设备”的专利,...
今日重磅消息“娱网皮球开挂器?... 网上科普关于“娱网皮球有没有挂”话题很是火热,小编也是针对娱网皮球作*弊开挂的方法以及开挂对应的知识...
广州在全国率先设立区级人工智能... 【环球网科技综合报道】12月29日消息,记者从广州海珠发布平台获悉,日前广州市海珠区人工智能发展局成...
玩家分享攻略“麦穗推筒子开挂器... 网上科普关于“麦穗推筒子有没有挂”话题很是火热,小编也是针对麦穗推筒子作*弊开挂的方法以及开挂对应的...
【第一资讯】“新好游炸/金/花... 有 亲,根据资深记者爆料新好游炸/金/花是可以开挂的,确实有挂(咨询软件...
今日重大消息“情怀娱乐究竟有挂... 有 亲,根据资深记者爆料情怀娱乐是可以开挂的,确实有挂(咨询软件无需打开...
今日重大发现“新版九哥开挂神器... 今日重大发现“新版九哥开挂神器?”(原来真的有挂)您好,新版九哥这个游戏其实有挂的,确实是有挂的,需...
今日重磅消息“海贝大厅牛牛有挂... 网上科普关于“海贝大厅牛牛有没有挂”话题很是火热,小编也是针对海贝大厅牛牛作*弊开挂的方法以及开挂对...
玩家攻略科普“飞驰娱乐到底是不... 有 亲,根据资深记者爆料飞驰娱乐是可以开挂的,确实有挂(咨询软件无需打开...