最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

MySQL如何查看元数据锁阻塞在哪里

来源:动视网 责编:小采 时间:2020-11-09 20:29:40
文档

MySQL如何查看元数据锁阻塞在哪里

MySQL如何查看元数据锁阻塞在哪里:MySQL如何查看元数据锁阻塞在哪里 操作步骤: 1、session 1 执行: start transaction; select *from t1; 2、session 2 在第1步执行完后执行: drop table t1; 此时session 2的drop语句被阻塞。那么怎么分析查看元数据锁呢?
推荐度:
导读MySQL如何查看元数据锁阻塞在哪里:MySQL如何查看元数据锁阻塞在哪里 操作步骤: 1、session 1 执行: start transaction; select *from t1; 2、session 2 在第1步执行完后执行: drop table t1; 此时session 2的drop语句被阻塞。那么怎么分析查看元数据锁呢?


MySQL如何查看元数据锁阻塞在哪里

操作步骤:

1、session 1 执行:

 start transaction;
 select *from t1;

2、session 2 在第1步执行完后执行:  

 drop table t1;

此时session 2的drop语句被阻塞。那么怎么分析查看元数据锁呢?

方法:

1)执行show processlist;,可以看到drop语句在等待元数据锁

mysql> show processlist; 
+----+-------------+-----------+------+---------+---------+-----------------------------------------------------------------------------+------------------+ 
| Id | User | Host | db | Command | Time | State | Info | 
+----+-------------+-----------+------+---------+---------+-----------------------------------------------------------------------------+------------------+ 
| 5 | system user | | NULL | Connect | 1050234 | Waiting for master to send event | NULL | 
| 6 | system user | | NULL | Connect | 983193 | Slave has read all relay log; waiting for the slave I/O thread to update it | NULL | 
| 8 | root | localhost | yzs | Sleep | 93 | | NULL | 
| 9 | root | localhost | yzs | Query | 3 | Waiting for table metadata lock | drop table t1 | 
| 10 | root | localhost | NULL | Query | 0 | init | show processlist | 
+----+-------------+-----------+------+---------+---------+-----------------------------------------------------------------------------+------------------+ 
5 rows in set (0.00 sec) 

2)可以看到当前正在运行的事务的线程是trx_mysql_thread_id:8,那么这个线程在干什么呢?

mysql> select *from information_schema.innodb_trx\G 
*************************** 1. row *************************** 
 trx_id: 17683 
 trx_state: RUNNING 
 trx_started: 2017-10-18 05:32:46 
 trx_requested_lock_id: NULL 
 trx_wait_started: NULL 
 trx_weight: 0 
 trx_mysql_thread_id: 8 
 trx_query: NULL 
 trx_operation_state: NULL 
 trx_tables_in_use: 0 
 trx_tables_locked: 0 
 trx_lock_structs: 0 
 trx_lock_memory_bytes: 320 
 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: 10000 
 trx_is_read_only: 0 
trx_autocommit_non_locking: 0 
1 row in set (0.03 sec) 

3)可以看到这个线程执行的是select语句,如果执行show engine innodb status;可以看到该事务处于sleep状态,也就是说这个事务语句执行完了,但是没有提交。

执行kill 8,将该事务的线程杀掉就可以了。或者检查业务的SQL语句,检查下是否有未提交的SQL语句。

mysql> select *from performance_schema.events_statements_current\G 
*************************** 1. row *************************** 
 THREAD_ID: 27 
 EVENT_ID: 15 
 END_EVENT_ID: 15 
 EVENT_NAME: statement/sql/select 
 SOURCE: mysqld.cc:962 
 TIMER_START: 1050544992900922000 
 TIMER_END: 1050544993740836000 
 TIMER_WAIT: 839914000 
 LOCK_TIME: 196000000 
 SQL_TEXT: select *from t1 
 DIGEST: 1aa32397c8ec37230aed78ef16126571 
 DIGEST_TEXT: SELECT * FROM `t1` 
 CURRENT_SCHEMA: yzs 
 OBJECT_TYPE: NULL 
 OBJECT_SCHEMA: NULL 
 OBJECT_NAME: NULL 
 OBJECT_INSTANCE_BEGIN: NULL 
 MYSQL_ERRNO: 0 
 RETURNED_SQLSTATE: NULL 
 MESSAGE_TEXT: NULL 
 ERRORS: 0 
 WARNINGS: 0 
 ROWS_AFFECTED: 0 
 ROWS_SENT: 10 
 ROWS_EXAMINED: 10 
CREATED_TMP_DISK_TABLES: 0 
 CREATED_TMP_TABLES: 0 
 SELECT_FULL_JOIN: 0 
 SELECT_FULL_RANGE_JOIN: 0 
 SELECT_RANGE: 0 
 SELECT_RANGE_CHECK: 0 
 SELECT_SCAN: 1 
 SORT_MERGE_PASSES: 0 
 SORT_RANGE: 0 
 SORT_ROWS: 0 
 SORT_SCAN: 0 
 NO_INDEX_USED: 1 
 NO_GOOD_INDEX_USED: 0 
 NESTING_EVENT_ID: NULL 
 NESTING_EVENT_TYPE: NULL 

如有疑问请留言或者到本站社区交流讨论,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

您可能感兴趣的文章:

  • Mysql查询正在执行的事务以及等待锁的操作方式
  • 基于更新SQL语句理解MySQL锁定详解
  • PHP利用Mysql锁解决高并发的方法
  • PHP+MySQL高并发加锁事务处理问题解决方法
  • MySQL锁机制与用法分析
  • MySQL语句加锁的实现分析
  • Mysql使用kill命令解决死锁问题(杀死某条正在执行的sql语句)
  • MYSQL 解锁与锁表介绍
  • 一次Mysql死锁排查过程的全纪录
  • MySQL对于各种锁的概念理解
  • 文档

    MySQL如何查看元数据锁阻塞在哪里

    MySQL如何查看元数据锁阻塞在哪里:MySQL如何查看元数据锁阻塞在哪里 操作步骤: 1、session 1 执行: start transaction; select *from t1; 2、session 2 在第1步执行完后执行: drop table t1; 此时session 2的drop语句被阻塞。那么怎么分析查看元数据锁呢?
    推荐度:
    标签: 堵塞 阻塞 mysql
    • 热门焦点

    最新推荐

    猜你喜欢

    热门推荐

    专题
    Top