MySQL InnoDB 鎖等待和鎖等待超時(shí)的處理

1. Innodb 引擎表行鎖等待和等待超時(shí)發(fā)生的場(chǎng)景

當(dāng)一個(gè)MySQL 連接會(huì)話等待另外一個(gè)會(huì)話持有的互斥行鎖時(shí),會(huì)發(fā)生 Innodb 引擎表行鎖等待情況。
通常情況下,持有該互斥行鎖的會(huì)話(連接)會(huì)迅速的執(zhí)行完相關(guān)操作并釋放掉持有的互斥鎖(事務(wù)提交或者回滾),進(jìn)而等待的會(huì)話在行鎖等待超時(shí)時(shí)間到來(lái)前獲得該互斥行鎖,進(jìn)行下一步操作。
但在某些情況下,比如一個(gè)實(shí)例未感知到的來(lái)自客戶端應(yīng)用的數(shù)據(jù)庫(kù)會(huì)話中斷,持有該互斥行鎖的會(huì)話長(zhǎng)時(shí)間不釋放該互斥行鎖,此時(shí)如果有其他會(huì)話申請(qǐng)?jiān)摶コ庑墟i,則會(huì)導(dǎo)致大量的行鎖等待與行鎖等待超時(shí)。

2. Innodb 引擎行鎖等待情況的處理

本文提供的檢查和處理方法,僅當(dāng)正在發(fā)生 InnoDB 行鎖等待的情況下才成立;因?yàn)?InnoDB 行鎖等待默認(rèn)超時(shí)時(shí)間為50秒,因此通常情況下不容易觀察到行鎖等待現(xiàn)場(chǎng),可以通過(guò)將 innodb_lock_wait_timeout 參數(shù)設(shè)置為較大值來(lái)復(fù)現(xiàn)問(wèn)題(生產(chǎn)環(huán)境不推薦使用過(guò)大的 innodb_lock_wait_timeout 參數(shù)值)。
該參數(shù)控制 Innodb 行鎖等待的超時(shí)時(shí)間,單位為秒,該實(shí)例該參數(shù)的默認(rèn)值為 50(秒)。

等待互斥鎖的會(huì)話在等待 50 秒后會(huì)退出鎖等待狀態(tài)并返回下面的錯(cuò)誤,這個(gè)行為稱之為 Innodb 引擎表行鎖等待超時(shí)。

 ERROR 1205 (HY000): Lock wait timeout exceeded; try restarting transaction 
Paste_Image.png

可以通過(guò)下面的命令查看當(dāng)前會(huì)話和全局的參數(shù)設(shè)置。

show variables like ‘innodb_lock_wait_timeout’; — 查看當(dāng)前會(huì)話show global variables like ‘innodb_lock_w%’; — 查看全局設(shè)置

該參數(shù)支持在會(huì)話級(jí)別修改,方便應(yīng)用在會(huì)話級(jí)別單獨(dú)設(shè)置某些特殊操作的行鎖等待超時(shí)時(shí)間,如下:

set innodb_lock_wait_timeout=1000; 

—設(shè)置當(dāng)前會(huì)話 Innodb 行鎖等待超時(shí)時(shí)間,單位秒+

2.2. 大量行鎖等待和行鎖等待超時(shí)的處理

如果行鎖等待和行鎖等待超時(shí)持續(xù)發(fā)生,并且導(dǎo)致當(dāng)前應(yīng)用運(yùn)行異常,那么需要獲取到一直持有行鎖的會(huì)話,并且終止該會(huì)話來(lái)釋放持有的鎖(會(huì)話對(duì)應(yīng)的事務(wù)會(huì)回滾)。

2.2.1 檢查導(dǎo)致鎖等待和鎖超時(shí)的會(huì)話
2.2.2 處理導(dǎo)致行鎖等待和行鎖等待超時(shí)的會(huì)話

對(duì)于標(biāo)識(shí)為 Blocker 的會(huì)話(持有鎖阻塞其他會(huì)話的 DML 操作,導(dǎo)致行鎖等待和行鎖等待超時(shí)),確認(rèn)業(yè)務(wù)可以接受其對(duì)應(yīng)的事務(wù)回滾的情況下,可以將其終止。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容