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

操作步骤:

1、session 1 执行:

   start transaction;   select *from t1;
  drop table t1;

方法:

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) 
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) 

执行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 

更多相关文章

  1. MySQL系列多表连接查询92及99语法示例详解教程
  2. Linux下MYSQL 5.7 找回root密码的问题(亲测可用)
  3. MySQL 什么时候使用INNER JOIN 或 LEFT JOIN
  4. mybatisplus的坑 insert标签insert into select无参数问题的解决
  5. python起点网月票榜字体反爬案例
  6. 《Android开发从零开始》——25.数据存储(4)
  7. Android系统配置数据库注释(settings.db)
  8. Android中不同应用间实现SharedPreferences数据共享
  9. android图表ichartjs

随机推荐

  1. 数据分析中会常犯哪些错误,如何解决?
  2. 数学之美:数学究竟是如何被运用到生活中的
  3. SQL今日一题(16):3表连接
  4. SQL今日一题(10)
  5. SQL今日一题(11):窗口函数
  6. 2020年小红书校招数据分析笔试题
  7. SQL今日一题(12):去重后计数
  8. Android不同手机屏幕分辨率自适应
  9. 你真的了解概率吗?
  10. SQL今日一题(17):涨幅