日日操夜夜添-日日操影院-日日草夜夜操-日日干干-精品一区二区三区波多野结衣-精品一区二区三区高清免费不卡

公告:魔扣目錄網(wǎng)為廣大站長提供免費收錄網(wǎng)站服務,提交前請做好本站友鏈:【 網(wǎng)站目錄:http://www.ylptlb.cn 】, 免友鏈快審服務(50元/站),

點擊這里在線咨詢客服
新站提交
  • 網(wǎng)站:51998
  • 待審:31
  • 小程序:12
  • 文章:1030137
  • 會員:747

本文介紹了一個 MySQL 數(shù)據(jù)庫死鎖的案例和解決方案。

場景

生產(chǎn)環(huán)境出了一個偶現(xiàn)的數(shù)據(jù)庫死鎖問題,導致少部分業(yè)務處理失敗。

分析特征之后,發(fā)現(xiàn)是多個線程并發(fā)執(zhí)行同一個方法,更新關聯(lián)的數(shù)據(jù)時可能會出現(xiàn),把場景簡化概括一下:

  • 有一個數(shù)據(jù)表 tb1,主鍵名 id,有兩條 id 分別為 A1 和 A2 的記錄,對應的外鍵 fk_biz_no 相同;

  • 方法 myFunc,整體是一個事務;

  • 方法 myFunc 里的邏輯是先更新 tb1 里的一條記錄,執(zhí)行一些邏輯后,再更新該記錄的外鍵對應的所有記錄;

這樣 線程1 和 線程2 并發(fā)執(zhí)行 myFunc 方法時,示意如下:

線程1 先更新 A1,此時會對 A1 所在行加寫鎖,再更新 A1 和 A2,此時會同時給 A1 和 A2 所在行都加上寫鎖;

線程2 先更新 A2,此時會對 A2 所在行加寫鎖,再更新 A1 和 A2,此時會同時給 A1 和 A2 所在行都加上寫鎖。

如此一來,如果出現(xiàn)類似以下的執(zhí)行時序,則會形成死鎖:

帶著一點偽裝的 ABBA 死鎖。

解決方案

按照消除死鎖條件的思路,一般會想到將兩個線程里的加鎖順序改為一致,但是此場景并不完全適用。以下是幾種可行的方案:

方案一、對 myFunc 方法加分布式鎖,可以用需要更新的記錄的 fk_biz_no 作為鎖的 key,這樣同一個 fk_biz_no 的更新操作就會串行執(zhí)行;

方案二、在方法/事務的最開始,就提前把 A1A2 的寫鎖申請到(比如 SELECT ... FOR UPDATE),然后再執(zhí)行后續(xù)邏輯;

方案三、優(yōu)化 myFunc 方法里的邏輯,先將 A1 和 A2 的數(shù)據(jù)都處理好了,然后一次性更新 A1A2,即將方法里的兩次更新合并成一次更新;

方案一 和 方案二 效果類似,都是使同一 fk_biz_no 的更新操作串行了;而方法三則是消除了 ABBA 的情況(實際場景中有可能需要考慮并發(fā)執(zhí)行下的數(shù)據(jù)混亂、數(shù)據(jù)覆蓋的問題,那是另外的話題了,在此不展開)。

小結

來一起復習下死鎖的四個必要條件:

  • 互斥條件:一個資源每次只能被一個進程使用;

  • 請求與保持條件:一個進程因請求資源而阻塞時,對已獲得的資源保持不放;

  • 不剝奪條件:進程已獲得的資源,在末使用完之前,不能強行剝奪;

  • 循環(huán)等待條件:若干進程之間形成一種頭尾相接的循環(huán)等待資源關系。

預防和消除死鎖的思路,則無非是消除上述四個條件中的一個或多個。

分享到:
標簽:MySQL
用戶無頭像

網(wǎng)友整理

注冊時間:

網(wǎng)站:5 個   小程序:0 個  文章:12 篇

  • 51998

    網(wǎng)站

  • 12

    小程序

  • 1030137

    文章

  • 747

    會員

趕快注冊賬號,推廣您的網(wǎng)站吧!
最新入駐小程序

數(shù)獨大挑戰(zhàn)2018-06-03

數(shù)獨一種數(shù)學游戲,玩家需要根據(jù)9

答題星2018-06-03

您可以通過答題星輕松地創(chuàng)建試卷

全階人生考試2018-06-03

各種考試題,題庫,初中,高中,大學四六

運動步數(shù)有氧達人2018-06-03

記錄運動步數(shù),積累氧氣值。還可偷

每日養(yǎng)生app2018-06-03

每日養(yǎng)生,天天健康

體育訓練成績評定2018-06-03

通用課目體育訓練成績評定