查找數(shù)據(jù)庫死鎖的方法總結(jié)
1)通過應(yīng)用業(yè)務(wù)日志定位到問題代碼,找到相應(yīng)的事務(wù)對應(yīng)的sql枫夺;
2)找DBA執(zhí)行下show InnoDB STATUS看看最近死鎖的日志。
3)確定數(shù)據(jù)庫隔離級別。
如何盡可能避免死鎖
1)以固定的順序訪問表和行茉帅。比如對第2節(jié)兩個job批量更新的情形,簡單方法是對id列表先排序冻押,后執(zhí)行梨睁,這樣就避免了交叉等待鎖的情形;又比如對于3.1節(jié)的情形颠猴,將兩個事務(wù)的sql順序調(diào)整為一致关划,也能避免死鎖。
2)大事務(wù)拆小翘瓮。大事務(wù)更傾向于死鎖贮折,如果業(yè)務(wù)允許,將大事務(wù)拆小资盅。
3)在同一個事務(wù)中调榄,盡可能做到一次鎖定所需要的所有資源,減少死鎖概率呵扛。
4)降低隔離級別每庆。如果業(yè)務(wù)允許,將隔離級別調(diào)低也是較好的選擇今穿,比如將隔離級別從RR調(diào)整為RC缤灵,可以避免掉很多因為gap鎖造成的死鎖。
5)為表添加合理的索引∪觯可以看到如果不走索引將會為表的每一行記錄添加上鎖帖鸦,死鎖的概率大大增
引文:https://blog.csdn.net/zhongyangjian/article/details/51968675