mysql怎么處理死鎖
mysql有兩種死鎖處理方式:
等待,直到超時(shí)(innodb_lock_wait_timeout=50s)。
發(fā)起死鎖檢測,主動(dòng)回滾一條事務(wù),讓其他事務(wù)繼續(xù)執(zhí)行(innodb_deadlock_detect=on)。
由于性能原因,一般都是使用死鎖檢測來進(jìn)行處理死鎖。
死鎖檢測
死鎖檢測的原理是構(gòu)建一個(gè)以事務(wù)為頂點(diǎn)、鎖為邊的有向圖,判斷有向圖是否存在環(huán),存在即有死鎖。
回滾
檢測到死鎖之后,選擇插入更新或者刪除的行數(shù)最少的事務(wù)回滾,基于 information_schema.innodb_trx 表中的 trx_weight 字段來判斷。
避免發(fā)生死鎖的方法:
1、收集死鎖信息:
利用命令 show engine innodb status查看死鎖原因。
調(diào)試階段開啟 innodb_print_all_deadlocks,收集所有死鎖日志。
2、減少死鎖:
使用事務(wù),不使用 lock tables 。
保證沒有長事務(wù)。
操作完之后立即提交事務(wù),特別是在交互式命令行中。
如果在用 (select ... for update or select ... lock in share mode),嘗試降低隔離級別。
修改多個(gè)表或者多個(gè)行的時(shí)候,將修改的順序保持一致。
創(chuàng)建索引,可以使創(chuàng)建的鎖更少。
最好不要用 (select ... for update or select ... lock in share mode)。
如果上述都無法解決問題,那么嘗試使用 lock tables t1, t2, t3 鎖多張表
推薦:mysql教程
- SQL 語法
- SQL SELECT DISTINCT 語句
- SQL WHERE 子句
- SQL ORDER BY 關(guān)鍵字
- SQL INSERT 語句
- SQL SELECT TOP, LIMIT, ROWNUM 子句
- SQL LIKE 操作符
- SQL BETWEEN 操作符
- SQL INNER JOIN 關(guān)鍵字
- SQL LEFT JOIN 關(guān)鍵字
- SQL UNION 操作符
- SQL SELECT INTO 語句
- SQL CREATE TABLE 語句
- SQL 約束(Constraints)
- SQL NOT NULL 約束
- SQL CREATE INDEX 語句
- SQL ALTER TABLE 語句
- SQL GROUP BY 語句
- SQL HAVING 子句
- SQL NULL 值