這篇文章將為大家詳細講解有關MySQL處理死鎖的方法,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
為宜豐等地區(qū)用戶提供了全套網頁設計制作服務,及宜豐網站建設行業(yè)解決方案。主營業(yè)務為網站制作、成都做網站、宜豐網站設計,以傳統(tǒng)方式定制建設網站,并提供域名空間備案等一條龍服務,秉承以專業(yè)、用心的態(tài)度為用戶提供真誠的服務。我們深信只要達到每一位用戶的要求,就會得到認可,從而選擇與我們長期合作。這樣,我們也可以走得更遠!
MySQL有兩種死鎖處理方式:
等待,直到超時(innodb_lock_wait_timeout=50s)。
發(fā)起死鎖檢測,主動回滾一條事務,讓其他事務繼續(xù)執(zhí)行(innodb_deadlock_detect=on)。
由于性能原因,一般都是使用死鎖檢測來進行處理死鎖。
死鎖檢測
死鎖檢測的原理是構建一個以事務為頂點、鎖為邊的有向圖,判斷有向圖是否存在環(huán),存在即有死鎖。
回滾
檢測到死鎖之后,選擇插入更新或者刪除的行數(shù)最少的事務回滾,基于 INFORMATION_SCHEMA.INNODB_TRX 表中的 trx_weight 字段來判斷。
避免發(fā)生死鎖的方法:
1、收集死鎖信息:
利用命令 SHOW ENGINE INNODB STATUS查看死鎖原因。
調試階段開啟 innodb_print_all_deadlocks,收集所有死鎖日志。
2、減少死鎖:
使用事務,不使用 lock tables 。
保證沒有長事務。
操作完之后立即提交事務,特別是在交互式命令行中。
如果在用 (SELECT ... FOR UPDATE or SELECT ... LOCK IN SHARE MODE),嘗試降低隔離級別。
修改多個表或者多個行的時候,將修改的順序保持一致。
創(chuàng)建索引,可以使創(chuàng)建的鎖更少。
最好不要用 (SELECT ... FOR UPDATE or SELECT ... LOCK IN SHARE MODE)。
如果上述都無法解決問題,那么嘗試使用 lock tables t1, t2, t3 鎖多張表
關于Mysql處理死鎖的方法就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
分享文章:Mysql處理死鎖的方法
文章起源:http://muchs.cn/article2/pdgpic.html
成都網站建設公司_創(chuàng)新互聯(lián),為您提供Google、品牌網站制作、網站內鏈、企業(yè)建站、全網營銷推廣、靜態(tài)網站
聲明:本網站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)