欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MySQL8.0 鎖等待排查的問(wèn)題解決

 更新時(shí)間:2024年10月28日 11:29:48   作者:Bing@DBA  
MySQL 5.7 一些鎖監(jiān)控表,在 8.0 都發(fā)生了變化,本文主要介紹了MySQL8.0如何排查鎖等待問(wèn)題,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

前言

MySQL 5.7 版本的時(shí)候鎖等待排查用的元數(shù)據(jù),主要存儲(chǔ)在 information_schema 庫(kù)下的 INNODB_LOCKS 和 INNODB_LOCK_WAITS 表,8.0 版本這兩張表刪除了,在 performance_schema 提供新的鎖相關(guān)的表,本篇文章將結(jié)合這些改動(dòng),介紹 MySQL 8.0 版本如何排查鎖等待問(wèn)題。

1. data_locks

performance_schema 庫(kù)中的 data_locks 可以觀測(cè) MySQL 中的鎖,對(duì)于 InnoDB 引擎可以觀測(cè)到表鎖、行鎖、Gap 鎖、Next-key 鎖。值得注意的是 data_locks 表無(wú)論鎖是否處理等待狀態(tài),都會(huì)記錄,所以有利于用戶通過(guò)該表測(cè)試 MySQL 的加鎖邏輯。

  • ENGINE:持有鎖的存儲(chǔ)引擎。
  • ENGINE_LOCK_ID:內(nèi)部格式,用戶可忽略。
  • ENGINE_TRANSACTION_ID:事務(wù) ID 可以與 INFORMATION_SCHEMA INNODB_TRX 表的 trx_id 字段關(guān)聯(lián)起來(lái)。
  • THREAD_ID:創(chuàng)建鎖的線程 ID,一般用不著,通過(guò)事務(wù) ID 就可以定位到會(huì)話連接。
  • EVENT_ID:與 THREAD_ID 組合使用,可以從 events 表中查到 SQL 語(yǔ)句。
  • OBJECT_SCHEMA:鎖定的數(shù)據(jù)庫(kù)名稱(chēng)。
  • OBJECT_NAME:鎖定表的名稱(chēng)。
  • PARTITION_NAME:鎖定分區(qū)的名稱(chēng),如果不是分區(qū)表為 NULL。
  • SUBPARTITION_NAME:鎖定子分區(qū)的名稱(chēng),如果不是分區(qū)表為 NULL。
  • INDEX_NAME:索引的名稱(chēng)。
  • OBJECT_INSTANCE_BEGIN:鎖在內(nèi)存中的地址。
  • LOCK_TYPE:鎖的類(lèi)型,對(duì)于 InnoDB,允許的值是 RECORD 行級(jí)鎖, TABLE 對(duì)于表級(jí)鎖。
  • LOCK_MODE:鎖的行為,用來(lái)標(biāo)記是意向鎖、寫(xiě)鎖、讀鎖、間隙鎖、Next-key 鎖。
  • LOCK_STATUS:鎖請(qǐng)求的狀態(tài),對(duì)于 InnoDB 引擎有 GRANTED 已持有和 WAITING 正在等待鎖,兩種狀態(tài)。
  • LOCK_DATA:如果是在主鍵加鎖,顯示主鍵值,如果是二級(jí)索引加鎖顯示二級(jí)索引的值和對(duì)應(yīng)主鍵的值。

下面的 SQL 是精簡(jiǎn)過(guò)的,只保留了常用的字段:

select ENGINE_TRANSACTION_ID, OBJECT_SCHEMA, OBJECT_NAME, INDEX_NAME, LOCK_TYPE, LOCK_MODE, LOCK_STATUS, LOCK_DATA from performance_schema.data_locks;

Session 1:鎖定 test_semi 全表。

begin;
select * from test_semi for update;
+----+------+------+
| a  | b    | c    |
+----+------+------+
| 10 |    1 |  123 |
| 11 |    2 |  123 |
| 12 |    1 |  123 |
| 13 |    2 |  123 |
| 14 |    1 |  123 |
+----+------+------+

Session 2:由下表可以看出 test_semi 表中每行都在主鍵上加寫(xiě)鎖,在 test_semi 表上加入 IX 意向鎖。

ENGINE_TRANSACTION_IDOBJECT_SCHEMAOBJECT_NAMEINDEX_NAMELOCK_TYPELOCK_MODELOCK_STATUSLOCK_DATA
6711testtest_semiNULLTABLEIXGRANTEDNULL
6711testtest_semiPRIMARYRECORDX,REC_NOT_GAPGRANTED10
6711testtest_semiPRIMARYRECORDX,REC_NOT_GAPGRANTED11
6711testtest_semiPRIMARYRECORDX,REC_NOT_GAPGRANTED12
6711testtest_semiPRIMARYRECORDX,REC_NOT_GAPGRANTED13
6711testtest_semiPRIMARYRECORDX,REC_NOT_GAPGRANTED14

2. data_lock_waits

performance_schema 庫(kù)中的 data_lock_waits 表可以觀測(cè)鎖等待的情況,只有發(fā)生堵塞的時(shí)候才會(huì)記錄。如果你發(fā)現(xiàn)這張表的記錄很多,說(shuō)明目前數(shù)據(jù)庫(kù)有很多鎖等待的情況。

  • ENGINE:存儲(chǔ)引擎。
  • REQUESTING_ENGINE_LOCK_ID:存儲(chǔ)引擎請(qǐng)求的鎖的 ID。
  • REQUESTING_ENGINE_TRANSACTION_ID:被堵塞的事務(wù) ID 可以與 INFORMATION_SCHEMA INNODB_TRX 表的 trx_id 字段關(guān)聯(lián)起來(lái)。
  • REQUESTING_THREAD_ID:請(qǐng)求鎖的會(huì)話的線程 ID。
  • REQUESTING_EVENT_ID:在請(qǐng)求鎖的會(huì)話中導(dǎo)致鎖請(qǐng)求的性能模式事件。
  • REQUESTING_OBJECT_INSTANCE_BEGIN:請(qǐng)求的鎖在內(nèi)存中的地址。
  • BLOCKING_ENGINE_LOCK_ID:阻塞鎖的 ID,可以與 data_locks 表的 ENGINE_LOCK_ID 字段進(jìn)行關(guān)聯(lián)。
  • BLOCKING_ENGINE_TRANSACTION_ID:持有鎖的事務(wù) ID 可以與 INFORMATION_SCHEMA INNODB_TRX 表的 trx_id 字段關(guān)聯(lián)起來(lái)。
  • BLOCKING_THREAD_ID:持有阻塞鎖的會(huì)話的線程 ID。
  • BLOCKING_EVENT_ID:導(dǎo)致持有該鎖的會(huì)話中出現(xiàn)阻塞鎖的性能模式事件。
  • BLOCKING_OBJECT_INSTANCE_BEGIN:阻塞鎖在內(nèi)存中的地址。

基于該表與事務(wù)表的關(guān)聯(lián)可以獲得當(dāng)前堵塞的事務(wù)信息:

select 
   trx.trx_id as waiting_trx_id,
   trx.trx_mysql_thread_id as waiting_thread_id,
   trx.trx_state as waiting_trx_state,
   trx.trx_query as waiting_query,
   lk.BLOCKING_ENGINE_TRANSACTION_ID as blocking_trx_id,
   lk.BLOCKING_THREAD_ID as blocking_thread_id,
   trx.trx_wait_started as trx_wait_started,
   TIMESTAMPDIFF(SECOND, trx.trx_wait_started, CURRENT_TIMESTAMP) as wait_second
from 
  performance_schema.data_lock_waits as lk 
  join information_schema.INNODB_TRX as trx on lk.REQUESTING_ENGINE_TRANSACTION_ID = trx.trx_id;
  • waiting_trx_id:被堵塞的事務(wù) ID。
  • waiting_thread_id:被堵塞的線程 ID。
  • waiting_trx_state:被堵塞事務(wù)的狀態(tài)。
  • waiting_query:被堵塞事務(wù)的語(yǔ)句。
  • blocking_trx_id:堵塞該事務(wù)的事務(wù) ID。
  • blocking_thread_id:堵塞該事務(wù)的線程 ID,如果查詢(xún)返回很多行,且大部分該值都相同,說(shuō)明堵塞源都相同,可通過(guò)該 ID 查到會(huì)話 ID 并 kill 掉。
  • trx_wait_started:被堵塞事務(wù)的開(kāi)始時(shí)間。
  • wait_second:鎖堵塞的時(shí)間長(zhǎng),單位為秒。

3. sys.innodb_lock_waits

sys 庫(kù)里面大部分表都是視圖,MySQL 創(chuàng)建該庫(kù)的原因是為了簡(jiǎn)化 performance_schema 表的使用難度,該庫(kù)里面提供一個(gè)視圖,可以查到非常詳細(xì)的鎖堵塞信息。

*************************** 1. row ***************************
                wait_started: 2024-08-06 15:37:36
                    wait_age: 00:00:11
               wait_age_secs: 11
                locked_table: `test`.`test_semi`
         locked_table_schema: test
           locked_table_name: test_semi
      locked_table_partition: NULL
   locked_table_subpartition: NULL
                locked_index: PRIMARY
                 locked_type: RECORD
              waiting_trx_id: 421847145074688
         waiting_trx_started: 2024-08-06 15:37:36
             waiting_trx_age: 00:00:11
     waiting_trx_rows_locked: 1
   waiting_trx_rows_modified: 0
                 waiting_pid: 818473
               waiting_query: select * from test_semi for share
             waiting_lock_id: 140372168364032:10:4:2:140372080646752
           waiting_lock_mode: S,REC_NOT_GAP
             blocking_trx_id: 6711
                blocking_pid: 819104
              blocking_query: NULL
            blocking_lock_id: 140372168364840:10:4:2:140372080652768
          blocking_lock_mode: X,REC_NOT_GAP
        blocking_trx_started: 2024-08-06 14:35:20
            blocking_trx_age: 01:02:27
    blocking_trx_rows_locked: 5
  blocking_trx_rows_modified: 0
     sql_kill_blocking_query: KILL QUERY 819104
sql_kill_blocking_connection: KILL 819104

結(jié)果集合中還給出 kill 掉堵塞會(huì)話的 SQL,不過(guò)在云數(shù)據(jù)庫(kù)上面 sys 庫(kù)一般都沒(méi)有給用戶權(quán)限。

4. 狀態(tài)變量

可通過(guò)下方狀態(tài)變量了解數(shù)據(jù)庫(kù)中的行鎖信息:

  • Innodb_row_lock_current_waits:當(dāng)前正在等待行鎖的操作數(shù)。
  • Innodb_row_lock_time:獲取行鎖花費(fèi)的總時(shí)間,單位毫秒。
  • Innodb_row_lock_time_avg:獲取行鎖花費(fèi)的平均時(shí)間,單位毫秒。
  • Innodb_row_lock_time_max:獲取行鎖花費(fèi)的最大時(shí)間,單位毫秒。

下面我們來(lái)做一個(gè)實(shí)驗(yàn):

root@mysql 14:38:  [(none)]>show status like '%Innodb_row_lock%';
+-------------------------------+-------+
| Variable_name                 | Value |
+-------------------------------+-------+
| Innodb_row_lock_current_waits | 0     |
| Innodb_row_lock_time          | 33165 |
| Innodb_row_lock_time_avg      | 16582 |
| Innodb_row_lock_time_max      | 28845 |
| Innodb_row_lock_waits         | 2     |
+-------------------------------+-------+
Session 1Session 2
Begin;
delete from score where id = 5;
update score set number = 66 where id = 5; – 等待行鎖
root@mysql 14:41:  [test]>show status like '%Innodb_row_lock%';
+-------------------------------+-------+
| Variable_name                 | Value |
+-------------------------------+-------+
| Innodb_row_lock_current_waits | 1     |
| Innodb_row_lock_time          | 33165 |
| Innodb_row_lock_time_avg      | 11055 |
| Innodb_row_lock_time_max      | 28845 |
| Innodb_row_lock_waits         | 3     |
+-------------------------------+-------+

此時(shí)可以發(fā)現(xiàn) Innodb_row_lock_waits 和 Innodb_row_lock_current_waits 都增長(zhǎng)了,time 相關(guān)的變量需要等事務(wù)結(jié)束后才會(huì)進(jìn)行計(jì)算。

5. 狀態(tài)變量 bug

Innodb_row_lock_current_waits 從文檔描述來(lái)看,反映的是當(dāng)前數(shù)據(jù)庫(kù)行鎖的操作數(shù),不過(guò)該值有時(shí)會(huì)出現(xiàn)不準(zhǔn)的情況。有位研發(fā)問(wèn)我某云的監(jiān)控上顯示當(dāng)前數(shù)據(jù)庫(kù)的行鎖有 20 億個(gè),當(dāng)前數(shù)據(jù)庫(kù)還正常嗎?當(dāng)時(shí)嚇了一跳,會(huì)話沒(méi)有任何異常,而且使用剛才介紹的鎖排查方法,都沒(méi)有異常。最后發(fā)現(xiàn)監(jiān)控采集的是 Innodb_row_lock_current_waits 的值,最后發(fā)現(xiàn)該值非常不準(zhǔn),有 Bug,所以大家如果遇到此類(lèi)問(wèn)題,可以先忽略,自制鎖等待監(jiān)控可以查 data_lock_waits 表,但是頻次不建議太高。

Innodb_row_lock_current_waits Bug:https://bugs.mysql.com/bug.php?id=71520

總結(jié)

MySQL 5.7 一些鎖監(jiān)控表,在 8.0 都發(fā)生了變化,不過(guò) sys 庫(kù)的 innodb_lock_waits 兩個(gè)版本都通用,其實(shí)該表就是一個(gè)視圖,在兩個(gè)版本中的實(shí)現(xiàn)方式不一樣,作用都相同。

到此這篇關(guān)于MySQL8.0 鎖等待排查的問(wèn)題解決的文章就介紹到這了,更多相關(guān)MySQL 鎖等待排查內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 解決SQL文件導(dǎo)入MySQL數(shù)據(jù)庫(kù)1118錯(cuò)誤的問(wèn)題

    解決SQL文件導(dǎo)入MySQL數(shù)據(jù)庫(kù)1118錯(cuò)誤的問(wèn)題

    在使用Navicat導(dǎo)入SQL文件時(shí),有時(shí)會(huì)遇到報(bào)錯(cuò)問(wèn)題,這通常與MySQL版本差異或嚴(yán)格模式設(shè)置有關(guān),若報(bào)錯(cuò)提示rowsize長(zhǎng)度過(guò)長(zhǎng),可能是因?yàn)镸ySQL的嚴(yán)格模式開(kāi)啟導(dǎo)致,解決方法是檢查嚴(yán)格模式是否開(kāi)啟,若開(kāi)啟則需關(guān)閉
    2024-10-10
  • 解決Mysql5.7.17在windows下安裝啟動(dòng)時(shí)提示不成功問(wèn)題

    解決Mysql5.7.17在windows下安裝啟動(dòng)時(shí)提示不成功問(wèn)題

    這篇文章主要介紹了解決Mysql5.7.17在windows下安裝啟動(dòng)時(shí)提示不成功問(wèn)題,需要的朋友可以參考下
    2017-03-03
  • mysql免安裝版配置步驟詳解分享

    mysql免安裝版配置步驟詳解分享

    這篇文章主要介紹了mysql免安裝版配置步驟詳解,提供了二個(gè)網(wǎng)友的安裝方法,大家可以參考使用
    2013-12-12
  • Mysql開(kāi)啟慢SQL并分析原因

    Mysql開(kāi)啟慢SQL并分析原因

    今天小編就為大家分享一篇關(guān)于Mysql開(kāi)啟慢SQL并分析原因,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧
    2019-04-04
  • MySQL PHP語(yǔ)法淺析

    MySQL PHP語(yǔ)法淺析

    在本篇文章里小編給大家分享了關(guān)于MySQL PHP語(yǔ)法的相關(guān)知識(shí)點(diǎn),需要的朋友們學(xué)習(xí)參考下。
    2019-02-02
  • MySQL設(shè)置用戶權(quán)限的簡(jiǎn)單步驟

    MySQL設(shè)置用戶權(quán)限的簡(jiǎn)單步驟

    這篇文章主要給大家介紹了關(guān)于MySQL設(shè)置用戶權(quán)限的簡(jiǎn)單步驟,學(xué)習(xí)MySQL數(shù)據(jù)庫(kù),MySQL用戶權(quán)限設(shè)置是需要首先學(xué)習(xí)的,需要的朋友可以參考下
    2023-07-07
  • MYSQL數(shù)據(jù)庫(kù)基礎(chǔ)之Join操作原理

    MYSQL數(shù)據(jù)庫(kù)基礎(chǔ)之Join操作原理

    這篇文章主要給大家介紹了關(guān)于MYSQL數(shù)據(jù)庫(kù)基礎(chǔ)之Join操作原理的相關(guān)資料,連接(join)查詢(xún)是將兩個(gè)查詢(xún)的結(jié)果以“橫向?qū)印钡姆绞胶喜⑵饋?lái)的結(jié)果,需要的朋友可以參考下
    2021-07-07
  • MySql按時(shí),天,周,月進(jìn)行數(shù)據(jù)統(tǒng)計(jì)

    MySql按時(shí),天,周,月進(jìn)行數(shù)據(jù)統(tǒng)計(jì)

    這篇文章主要介紹了MySql按時(shí),天,周,月進(jìn)行數(shù)據(jù)統(tǒng)計(jì),文章圍繞主題展開(kāi)詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下
    2022-08-08
  • windows下mysql 5.7版本中修改編碼為utf-8的方法步驟

    windows下mysql 5.7版本中修改編碼為utf-8的方法步驟

    mysql的默認(rèn)編碼是拉丁(latin1),當(dāng)輸入中文的時(shí)候就會(huì)報(bào)錯(cuò),所以需要將編碼修改為utf8,從網(wǎng)上找了相關(guān)教程都不可以,索性自己摸索后分享給大家,下面這篇文章主要給大家介紹了在mysql 5.7版本中如何修改編碼為utf-8的方法步驟,需要的朋友可以參考下。
    2017-06-06
  • MySql數(shù)據(jù)庫(kù)查詢(xún)中的特殊命令

    MySql數(shù)據(jù)庫(kù)查詢(xún)中的特殊命令

    本文給大家介紹了MySql數(shù)據(jù)庫(kù)查詢(xún)中的特殊命令,包括mysql的安裝,特殊查詢(xún)語(yǔ)句,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下
    2017-11-11

最新評(píng)論