自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

一個(gè) MySQL 數(shù)據(jù)庫(kù)死鎖的案例和解決方案

數(shù)據(jù)庫(kù) MySQL
按照消除死鎖條件的思路,一般會(huì)想到將兩個(gè)線程里的加鎖順序改為一致,但是此場(chǎng)景并不完全適用。

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

場(chǎng)景

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

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

  • 有一個(gè)數(shù)據(jù)表 tb1,主鍵名 id,有兩條 id 分別為 A1 和 A2 的記錄,對(duì)應(yīng)的外鍵 fk_biz_no 相同;
  • 方法 myFunc,整體是一個(gè)事務(wù);
  • 方法 myFunc 里的邏輯是先更新 tb1 里的一條記錄,執(zhí)行一些邏輯后,再更新該記錄的外鍵對(duì)應(yīng)的所有記錄;

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

線程1 先更新 A1,此時(shí)會(huì)對(duì) A1 所在行加寫鎖,再更新 A1 和 A2,此時(shí)會(huì)同時(shí)給 A1 和 A2 所在行都加上寫鎖;

線程2 先更新 A2,此時(shí)會(huì)對(duì) A2 所在行加寫鎖,再更新 A1 和 A2,此時(shí)會(huì)同時(shí)給 A1 和 A2 所在行都加上寫鎖。

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

帶著一點(diǎn)偽裝的 ABBA 死鎖。

解決方案

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

  • 方案一、對(duì) myFunc 方法加分布式鎖,可以用需要更新的記錄的 fk_biz_no 作為鎖的 key,這樣同一個(gè) fk_biz_no 的更新操作就會(huì)串行執(zhí)行;
  • 方案二、在方法/事務(wù)的最開始,就提前把 A1A2 的寫鎖申請(qǐng)到(比如 SELECT ... FOR UPDATE),然后再執(zhí)行后續(xù)邏輯;
  • 方案三、優(yōu)化 myFunc 方法里的邏輯,先將 A1 和 A2 的數(shù)據(jù)都處理好了,然后一次性更新 A1A2,即將方法里的兩次更新合并成一次更新;

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

小結(jié)

來(lái)一起復(fù)習(xí)下死鎖的四個(gè)必要條件:

  • 互斥條件:一個(gè)資源每次只能被一個(gè)進(jìn)程使用;
  • 請(qǐng)求與保持條件:一個(gè)進(jìn)程因請(qǐng)求資源而阻塞時(shí),對(duì)已獲得的資源保持不放;
  • 不剝奪條件:進(jìn)程已獲得的資源,在末使用完之前,不能強(qiáng)行剝奪;
  • 循環(huán)等待條件:若干進(jìn)程之間形成一種頭尾相接的循環(huán)等待資源關(guān)系。

預(yù)防和消除死鎖的思路,則無(wú)非是消除上述四個(gè)條件中的一個(gè)或多個(gè)。

責(zé)任編輯:趙寧寧 來(lái)源: 悶騷的程序員
相關(guān)推薦

2011-08-05 13:41:18

mysql數(shù)據(jù)庫(kù)數(shù)據(jù)庫(kù)配置

2011-03-07 16:42:05

MySQL數(shù)據(jù)庫(kù)安全

2020-03-11 09:57:10

數(shù)據(jù)安全網(wǎng)絡(luò)安全網(wǎng)絡(luò)攻擊

2010-05-27 18:24:09

MySQL數(shù)據(jù)庫(kù)密碼

2011-03-28 13:11:18

MySQL數(shù)據(jù)庫(kù)安全

2024-11-12 15:42:06

2011-07-25 09:32:28

2011-08-04 18:55:53

SQL Server 用戶sa登錄失敗

2010-05-28 11:22:07

2011-07-18 09:36:42

Mysql數(shù)據(jù)庫(kù)root@localh

2009-11-18 16:10:00

2018-03-26 12:58:52

數(shù)據(jù)庫(kù)OracleMySQL

2010-06-04 19:06:47

連接MySQL數(shù)據(jù)庫(kù)

2011-03-03 18:09:14

2022-03-31 10:25:20

物聯(lián)網(wǎng)工業(yè) 4.0大數(shù)據(jù)分析

2017-12-27 13:07:52

數(shù)據(jù)庫(kù)MySQL主從復(fù)制

2011-03-24 15:41:42

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

2011-01-21 09:43:10

安恒數(shù)據(jù)庫(kù)安全安全審計(jì)

2023-10-16 16:08:42

工業(yè) 4.0物聯(lián)網(wǎng)邊緣計(jì)算

2011-08-03 14:02:02

數(shù)據(jù)庫(kù)連接ACCESS
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)