數(shù)據(jù)庫(kù)死鎖

查找數(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

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容