創(chuàng)新互聯(lián)www.cdcxhl.cn八線動(dòng)態(tài)BGP香港云服務(wù)器提供商,新人活動(dòng)買(mǎi)多久送多久,劃算不套路!
網(wǎng)站設(shè)計(jì)制作過(guò)程拒絕使用模板建站;使用PHP+MYSQL原生開(kāi)發(fā)可交付網(wǎng)站源代碼;符合網(wǎng)站優(yōu)化排名的后臺(tái)管理系統(tǒng);成都網(wǎng)站設(shè)計(jì)、成都做網(wǎng)站、外貿(mào)網(wǎng)站建設(shè)收費(fèi)合理;免費(fèi)進(jìn)行網(wǎng)站備案等企業(yè)網(wǎng)站建設(shè)一條龍服務(wù).我們是一家持續(xù)穩(wěn)定運(yùn)營(yíng)了十余年的成都創(chuàng)新互聯(lián)網(wǎng)站建設(shè)公司。這篇文章將為大家詳細(xì)講解有關(guān)Mysql處理死鎖的方法,小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。
MySQL有兩種死鎖處理方式:
等待,直到超時(shí)(innodb_lock_wait_timeout=50s)。
發(fā)起死鎖檢測(cè),主動(dòng)回滾一條事務(wù),讓其他事務(wù)繼續(xù)執(zhí)行(innodb_deadlock_detect=on)。
由于性能原因,一般都是使用死鎖檢測(cè)來(lái)進(jìn)行處理死鎖。
死鎖檢測(cè)
死鎖檢測(cè)的原理是構(gòu)建一個(gè)以事務(wù)為頂點(diǎn)、鎖為邊的有向圖,判斷有向圖是否存在環(huán),存在即有死鎖。
回滾
檢測(cè)到死鎖之后,選擇插入更新或者刪除的行數(shù)最少的事務(wù)回滾,基于 INFORMATION_SCHEMA.INNODB_TRX 表中的 trx_weight 字段來(lái)判斷。
避免發(fā)生死鎖的方法:
1、收集死鎖信息:
利用命令 SHOW ENGINE INNODB STATUS查看死鎖原因。
調(diào)試階段開(kāi)啟 innodb_print_all_deadlocks,收集所有死鎖日志。
2、減少死鎖:
使用事務(wù),不使用 lock tables 。
保證沒(méi)有長(zhǎng)事務(wù)。
操作完之后立即提交事務(wù),特別是在交互式命令行中。
如果在用 (SELECT ... FOR UPDATE or SELECT ... LOCK IN SHARE MODE),嘗試降低隔離級(jí)別。
修改多個(gè)表或者多個(gè)行的時(shí)候,將修改的順序保持一致。
創(chuàng)建索引,可以使創(chuàng)建的鎖更少。
最好不要用 (SELECT ... FOR UPDATE or SELECT ... LOCK IN SHARE MODE)。
如果上述都無(wú)法解決問(wèn)題,那么嘗試使用 lock tables t1, t2, t3 鎖多張表
關(guān)于Mysql處理死鎖的方法就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到。