亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么樣通過MySQL查看元數據鎖阻塞語句

發布時間:2020-05-06 14:35:37 來源:億速云 閱讀:193 作者:三月 欄目:MySQL數據庫

下文主要給大家帶來怎么樣通過MySQL查看元數據鎖阻塞語句,希望怎么樣通過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查看元數據鎖阻塞語句,大家是不是覺得非常有幫助。如果需要了解更多內容,請繼續關注我們的行業資訊,相信你會喜歡上這些內容的。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

马公市| 永嘉县| 东兴市| 微山县| 易门县| 古浪县| 洪雅县| 齐齐哈尔市| 墨脱县| 丰顺县| 诏安县| 榆树市| 贵州省| 南通市| 汉沽区| 绥阳县| 锦州市| 固安县| 怀集县| 喀什市| 五河县| 韶关市| 河东区| 保德县| 抚顺县| 济宁市| 大理市| 天水市| 泽州县| 金昌市| 华坪县| 惠东县| 吉安市| 康平县| 西贡区| 梁河县| 兴山县| 家居| 工布江达县| 苗栗市| 吉首市|