亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

關(guān)于MySQL數(shù)據(jù)庫死鎖的案例和解決方案

 更新時(shí)間:2023年09月01日 08:57:05   作者:mzlogin  
MySQL Update語句防止死鎖是指在修改MySQL數(shù)據(jù)庫的數(shù)據(jù)時(shí),為避免多個(gè)進(jìn)程同時(shí)修改同一數(shù)據(jù)行而造成死鎖的情況,引入了一些機(jī)制來防止死鎖的產(chǎn)生,本文介紹了一個(gè) MySQL 數(shù)據(jù)庫死鎖的案例和解決方案,需要的朋友可以參考下

場(chǎng)景

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

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

  • 有一個(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 所在行都加上寫鎖。

如此一來,如果出現(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ù)覆蓋的問題,那是另外的話題了,在此不展開)。

小結(jié)

來一起復(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ù)防和消除死鎖的思路,則無非是消除上述四個(gè)條件中的一個(gè)或多個(gè)。

到此這篇關(guān)于MySQL數(shù)據(jù)庫死鎖的案例和解決方案的文章就介紹到這了,更多相關(guān)MySQL死鎖內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • MySQL中日期格式化匹配的處理方式

    MySQL中日期格式化匹配的處理方式

    處理日期和時(shí)間數(shù)據(jù)是很常見的需求,本文主要介紹了SELECT?語句對(duì)日期進(jìn)行格式化匹配,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2024-08-08
  • Centos7下mysql 8.0.15 安裝配置圖文教程

    Centos7下mysql 8.0.15 安裝配置圖文教程

    這篇文章主要為大家詳細(xì)介紹了Centos7下mysql 8.0.15 安裝配置圖文教程,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-03-03
  • python 連接數(shù)據(jù)庫mysql解壓版安裝配置及遇到問題

    python 連接數(shù)據(jù)庫mysql解壓版安裝配置及遇到問題

    今天學(xué)習(xí)python連接數(shù)據(jù)庫,就想安裝一下mysql數(shù)據(jù)庫,沒想到小小的數(shù)據(jù)庫也遇到了不少挫折,所以我就把自己的安裝過程以及問題寫出來分享給大家,需要的朋友可以參考下
    2019-06-06
  • mysql當(dāng)中怎么執(zhí)行sql腳本文件

    mysql當(dāng)中怎么執(zhí)行sql腳本文件

    這篇文章主要給大家介紹了關(guān)于mysql當(dāng)中怎么執(zhí)行sql腳本文件的相關(guān)資料,需要的朋友可以參考下
    2023-08-08
  • mysql如何修改表結(jié)構(gòu)(alter table),多列/多字段

    mysql如何修改表結(jié)構(gòu)(alter table),多列/多字段

    這篇文章主要介紹了mysql如何修改表結(jié)構(gòu)(alter table),多列/多字段問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-12-12
  • mysql 鎖表鎖行語句分享(MySQL事務(wù)處理)

    mysql 鎖表鎖行語句分享(MySQL事務(wù)處理)

    下面這個(gè)語句是鎖定一行數(shù)據(jù),開始讀取,一直到刪除后都不會(huì)有第二個(gè)人也讀到這條數(shù)據(jù)
    2011-09-09
  • MySQL sum后再計(jì)算percentage的多種解決辦法

    MySQL sum后再計(jì)算percentage的多種解決辦法

    這篇文章主要介紹了MySQL sum后再計(jì)算percentage的多種解決辦法,over() 函數(shù),Cross Join,Select 嵌套查詢以及 with 函數(shù)處理,文中通過代碼示例講解的非常詳細(xì),需要的朋友可以參考下
    2024-06-06
  • mysql 5.7.20\5.7.21 免安裝版安裝配置教程

    mysql 5.7.20\5.7.21 免安裝版安裝配置教程

    這篇文章主要為大家詳細(xì)介紹了mysql5.7.20和mysql5.7.21免安裝版安裝配置教程,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-02-02
  • MySQL存儲(chǔ)過程的創(chuàng)建使用以及實(shí)現(xiàn)數(shù)據(jù)快速插入

    MySQL存儲(chǔ)過程的創(chuàng)建使用以及實(shí)現(xiàn)數(shù)據(jù)快速插入

    因最近想要測(cè)試一下MySQL百萬級(jí)數(shù)據(jù)處理過程,所以要一次對(duì)數(shù)據(jù)庫快速插入大量數(shù)據(jù),下面這篇文章主要給大家介紹了關(guān)于MySQL存儲(chǔ)過程的創(chuàng)建使用以及實(shí)現(xiàn)數(shù)據(jù)快速插入的相關(guān)資料,需要的朋友可以參考下
    2023-03-03
  • K8S搭建MySQL一主一從集群詳細(xì)步驟

    K8S搭建MySQL一主一從集群詳細(xì)步驟

    在k8s上命名空間是用于隔離不同應(yīng)用的一種機(jī)制,我們可以使用命名空間來組織和管理MySQL集群,這篇文章主要給大家介紹了關(guān)于K8S搭建MySQL一主一從集群的相關(guān)資料,需要的朋友可以參考下
    2023-09-09

最新評(píng)論