Mysql如何處理死鎖
MySQL有兩種死鎖處理方式:
等待,直到超時(innodb_lock_wait_timeout=50s)。
發起死鎖檢測,主動回滾一條事務,讓其他事務繼續執行(innodb_deadlock_detect=on)。
由於效能原因,一般都是使用死鎖檢測來進行處理死鎖。
死鎖檢測
死鎖檢測的原理是構建一個以事務為頂點、鎖為邊的有向圖,判斷有向圖是否存在環,存在即有死鎖。
回滾
檢測到死鎖之後,選擇插入更新或者刪除的行數最少的事務回滾,基於 INFORMATION_SCHEMA.INNODB_TRX 表中的 trx_weight 欄位來判斷。
避免發生死鎖的方法:
1、收集死鎖資訊:
利用命令 SHOW ENGINE INNODB STATUS檢視死鎖原因。
除錯階段開啟 innodb_print_all_deadlocks,收集所有死鎖日誌。
2、減少死鎖:
使用事務,不使用 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 鎖多張表
推薦:
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/1806/viewspace-2833729/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 如何處理執行緒死鎖執行緒
- 一次徹底講清如何處理mysql 的死鎖問題MySql
- 面試:什麼是死鎖,如何避免或解決死鎖;MySQL中的死鎖現象,MySQL死鎖如何解決面試MySql
- 【Oracle】死鎖的產生與處理Oracle
- MySQL 死鎖和鎖等待MySql
- 作業系統(5) 死鎖的概念 死鎖產生的必要條件 死鎖的處理策略 預防死鎖 避免死鎖 死鎖的檢測和解除 銀行家演算法作業系統演算法
- MySQL解決死鎖MySql
- MySQL死鎖問題MySql
- MySQL 死鎖解決MySql
- MySQL死鎖系列-線上死鎖問題排查思路MySql
- Mysql 兩階段鎖和死鎖MySql
- mysql行鎖和死鎖檢測MySql
- 什麼是死鎖?如何解決死鎖?
- mysql死鎖最佳化MySql
- MySQL列印死鎖日誌MySql
- MySQL:死鎖一例MySql
- MySQL 死鎖問題分析MySql
- MySQL:MTS和mysqldump死鎖MySql
- 【MySQL】死鎖案例之六MySql
- 【MySQL】死鎖案例之七MySql
- 【MySQL】死鎖案例之八MySql
- MySQL:一個死鎖分析 (未分析出來的死鎖)MySql
- mysql事務處理與鎖機制MySql
- 作業系統4——處理機排程與死鎖作業系統
- MySQL鎖等待與死鎖問題分析MySql
- SQL Server 資料庫查詢死鎖的處理步驟SQLServer資料庫
- MySQL insert on duplicate key update 死鎖MySql
- 故障分析 | MySQL死鎖案例分析MySql
- MySQL:Innodb 一個死鎖案例MySql
- MySQL批量更新死鎖案例分析MySql
- 死鎖是什麼?如何預防和避免死鎖?
- MySQL死鎖案例一(回滾導致死鎖)MySql
- MySQL死鎖案例二(自增列導致死鎖)MySql
- 剖析6個MySQL死鎖案例的原因以及死鎖預防策略MySql
- 如何避免死鎖和活鎖? - simar
- 記一個openwrt reboot非同步訊號處理死鎖問題boot非同步
- MySQL強人“鎖”難《死磕MySQL系列 三》MySql
- APM RUEI processor處理程式hang死處理方法