mysql處理死鎖 mysql如何處理死鎖問題

2021-10-18 03:32:57 字數 880 閱讀 2919

mysql有兩種死鎖處理方式:

1、等待,直到超時(innodb_lock_wait_timeout=50s);

2、發起死鎖檢測,主動回滾一條事務,讓其他事務繼續執行(innodb_deadlock_detect=on);

由於效能原因,一般都是使用死鎖檢測來進行處理死鎖。

死鎖檢測

死鎖檢測的原理是構建乙個以事務為頂點、鎖為邊的有向圖,判斷有向圖是否存在環,存在即有死鎖。

回滾檢測到死鎖之後,選擇插入更新或者刪除的行數最少的事務回滾,基於 information_schema.innodb_trx 表中的 trx_weight 欄位來判斷。

如何避免發生死鎖?

一、收集死鎖資訊:

利用命令 show engine innodb status檢視死鎖原因。

除錯階段開啟 innodb_print_all_deadlocks,收集所有死鎖日誌。

二、減少死鎖:

使用事務,不使用 lock tables 。

保證沒有長事務。

操作完之後立即提交事務,特別是在互動式命令列中。

如果在用 (select ... for update or select ... lock in share mode),嘗試降低隔離級別。

修改多個表或者多個行的時候,將修改的順序保持一致。

建立索引,可以使建立的鎖更少。

最好不要用 (select ... for update or select ... lock in share mode)。

如果上述都無法解決問題,那麼嘗試使用 lock tables t1, t2, t3 鎖多張表。

mysql 死鎖語句 MySQL死鎖

死鎖產生 行鎖的具體實現演算法有三種 record lock gap lock以及next key lock。record lock是專門對索引項加鎖 gap lock是對索引項之間的間隙加鎖 next key lock則是前面兩種的組合,對索引項及其之間的間隙加鎖。只在可重複讀或以上隔離級別下的特...

Mysql對死鎖的處理

官方定義如下 兩個事務都持有對方需要的鎖,並且在等待對方釋放,並且雙方都不會釋放自己的鎖。由於效能原因,一般都是使用死鎖檢測來進行處理死鎖。死鎖檢測的原理是構建乙個以事務為頂點 鎖為邊的有向圖,判斷有向圖是否存在環,存在即有死鎖。檢測到死鎖之後,選擇插入更新或者刪除的行數最少的事務回滾,基於info...

MySQL如何處理死鎖

官方定義如下 兩個事務都持有對方需要的鎖,並且在等待對方釋放,並且雙方都不會釋放自己的鎖。這個就好比你有乙個人質,對方有乙個人質,你們倆去談判說換人。你讓對面放人,對面讓你放人。看到這裡,也許你會有這樣的疑問,事務和談判不一樣,為什麼事務不能使用完鎖之後立馬釋放呢?居然還要操作完了之後一直持有鎖?這...