查找數(shù)據(jù)庫(kù)死鎖的方法總結(jié)
1)通過應(yīng)用業(yè)務(wù)日志定位到問題代碼,找到相應(yīng)的事務(wù)對(duì)應(yīng)的sql;
2)找DBA執(zhí)行下show InnoDB STATUS看看最近死鎖的日志。
3)確定數(shù)據(jù)庫(kù)隔離級(jí)別。
如何盡可能避免死鎖
1)以固定的順序訪問表和行。比如對(duì)第2節(jié)兩個(gè)job批量更新的情形,簡(jiǎn)單方法是對(duì)id列表先排序,后執(zhí)行,這樣就避免了交叉等待鎖的情形;又比如對(duì)于3.1節(jié)的情形,將兩個(gè)事務(wù)的sql順序調(diào)整為一致,也能避免死鎖。
2)大事務(wù)拆小。大事務(wù)更傾向于死鎖,如果業(yè)務(wù)允許,將大事務(wù)拆小。
3)在同一個(gè)事務(wù)中,盡可能做到一次鎖定所需要的所有資源,減少死鎖概率。
4)降低隔離級(jí)別。如果業(yè)務(wù)允許,將隔離級(jí)別調(diào)低也是較好的選擇,比如將隔離級(jí)別從RR調(diào)整為RC,可以避免掉很多因?yàn)間ap鎖造成的死鎖。
5)為表添加合理的索引??梢钥吹饺绻蛔咚饕龑?huì)為表的每一行記錄添加上鎖,死鎖的概率大大增
引文:https://blog.csdn.net/zhongyangjian/article/details/51968675