<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答1問答10問答100問答1000問答2000關(guān)鍵字專題1關(guān)鍵字專題50關(guān)鍵字專題500關(guān)鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關(guān)鍵字專題關(guān)鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
        問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
        當前位置: 首頁 - 科技 - 知識百科 - 正文

        由不同的索引更新解決MySQL死鎖套路

        來源:懂視網(wǎng) 責編:小采 時間:2020-11-09 21:14:45
        文檔

        由不同的索引更新解決MySQL死鎖套路

        由不同的索引更新解決MySQL死鎖套路:前幾篇文章介紹了用源碼的方式來調(diào)試鎖相關(guān)的信息,這里同樣用這個工具來解決一個線上實際的死鎖案例,也是我們介紹的第一個兩條 SQL 就造成死鎖的情況。因為線上的表結(jié)構(gòu)比較復(fù)雜,做了一些簡化以后如下 CREATE TABLE `t3` ( `id` int(11) N
        推薦度:
        導(dǎo)讀由不同的索引更新解決MySQL死鎖套路:前幾篇文章介紹了用源碼的方式來調(diào)試鎖相關(guān)的信息,這里同樣用這個工具來解決一個線上實際的死鎖案例,也是我們介紹的第一個兩條 SQL 就造成死鎖的情況。因為線上的表結(jié)構(gòu)比較復(fù)雜,做了一些簡化以后如下 CREATE TABLE `t3` ( `id` int(11) N

        前幾篇文章介紹了用源碼的方式來調(diào)試鎖相關(guān)的信息,這里同樣用這個工具來解決一個線上實際的死鎖案例,也是我們介紹的第一個兩條 SQL 就造成死鎖的情況。因為線上的表結(jié)構(gòu)比較復(fù)雜,做了一些簡化以后如下

        CREATE TABLE `t3` (
         `id` int(11) NOT NULL AUTO_INCREMENT,
         `a` varchar(5),
         `b` varchar(5),
         PRIMARY KEY (`id`),
         UNIQUE KEY `uk_a` (`a`),
         KEY `idx_b` (`b`) 
        )
        INSERT INTO `t3` (`id`, `a`, `b`) VALUES 
         (1,'1','2');
        # sql語句如下
        
        # 事務(wù)1:t1
        update t3 set b = '' where a = "1";
        
        # 事務(wù)2:t2
        update t3 set b = '' where b = "2";
        
        
        

        兩條語句造成死鎖的情況用手動的方式比較難復(fù)現(xiàn),我們先來分析一下加鎖的過程

        第一條語句(通過唯一索引去更新記錄)

        update t3 set b = '' where a = "1";

         

        整理一下,加了3個X鎖,順序分別是

        序號 索引 鎖類型
        1 uk_a X
        2 PRIMARY X
        3 idx_b X

        第二條語句

        update t3 set b = '' where b = "2";

        整理一下,加了 3 個 X 鎖,順序分別是

        序號 索引 鎖類型
        1 idx_b X
        2 PRIMARY X
        3 idx_b X

        兩條語句從加鎖順序看起來就已經(jīng)有構(gòu)成死鎖的條件了

        手動是比較難模擬的,寫個代碼并發(fā)的去同時執(zhí)行那兩條 SQL 語句,馬上就出現(xiàn)死鎖了

        ------------------------
        LATEST DETECTED DEADLOCK
        ------------------------
        181102 12:45:05
        *** (1) TRANSACTION:
        TRANSACTION 50AF, ACTIVE 0 sec starting index read
        mysql tables in use 1, locked 1
        LOCK WAIT 3 lock struct(s), heap size 376, 2 row lock(s)
        MySQL thread id 34, OS thread handle 0x70000d842000, query id 549 localhost 127.0.0.1 root Searching rows for update
        update t3 set b = '' where b = "2"
        *** (1) WAITING FOR THIS LOCK TO BE GRANTED:
        RECORD LOCKS space id 67 page no 3 n bits 72 index `PRIMARY` of table `d1`.`t3` trx id 50AF lock_mode X locks rec but not gap waiting
        Record lock, heap no 2 PHYSICAL RECORD: n_fields 5; compact format; info bits 0
         0: len 4; hex 80000001; asc ;;
         1: len 6; hex 0000000050ae; asc P ;;
         2: len 7; hex 03000001341003; asc 4 ;;
         3: len 1; hex 31; asc 1;;
         4: len 0; hex ; asc ;;
        
        *** (2) TRANSACTION:
        TRANSACTION 50AE, ACTIVE 0 sec updating or deleting
        mysql tables in use 1, locked 1
        4 lock struct(s), heap size 1248, 3 row lock(s), undo log entries 1
        MySQL thread id 35, OS thread handle 0x70000d885000, query id 548 localhost 127.0.0.1 root Updating
        update t3 set b = '' where a = "1"
        *** (2) HOLDS THE LOCK(S):
        RECORD LOCKS space id 67 page no 3 n bits 72 index `PRIMARY` of table `d1`.`t3` trx id 50AE lock_mode X locks rec but not gap
        Record lock, heap no 2 PHYSICAL RECORD: n_fields 5; compact format; info bits 0
         0: len 4; hex 80000001; asc ;;
         1: len 6; hex 0000000050ae; asc P ;;
         2: len 7; hex 03000001341003; asc 4 ;;
         3: len 1; hex 31; asc 1;;
         4: len 0; hex ; asc ;;
        
        *** (2) WAITING FOR THIS LOCK TO BE GRANTED:
        RECORD LOCKS space id 67 page no 5 n bits 72 index `idx_b` of table `d1`.`t3` trx id 50AE lock_mode X locks rec but not gap waiting
        Record lock, heap no 2 PHYSICAL RECORD: n_fields 2; compact format; info bits 0
         0: len 1; hex 32; asc 2;;
         1: len 4; hex 80000001; asc ;;
        
        *** WE ROLL BACK TRANSACTION (1)
        
        

        分析一下死鎖日志

        *** (1) WAITING FOR THIS LOCK TO BE GRANTED:
        RECORD LOCKS space id 67 page no 3 n bits 72 index PRIMARY of table d1.t3 trx id 50AF lock_mode X locks rec but not gap waiting

        事務(wù)2:想獲取主鍵索引的 X 鎖

        *** (2) HOLDS THE LOCK(S):
        RECORD LOCKS space id 67 page no 3 n bits 72 index PRIMARY of table d1.t3 trx id 50AE lock_mode X locks rec but not gap

        事務(wù)1:持有主鍵索引的 X 鎖

        *** (2) WAITING FOR THIS LOCK TO BE GRANTED:
        RECORD LOCKS space id 67 page no 5 n bits 72 index idx_b of table d1.t3 trx id 50AE lock_mode X locks rec but not gap waiting

        事務(wù)1:想獲取普通索引 idx_b 的 X 鎖

        與我們分析的完全一致,也與線上的死鎖日志一模一樣

        聲明:本網(wǎng)頁內(nèi)容旨在傳播知識,若有侵權(quán)等問題請及時與本網(wǎng)聯(lián)系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

        由不同的索引更新解決MySQL死鎖套路

        由不同的索引更新解決MySQL死鎖套路:前幾篇文章介紹了用源碼的方式來調(diào)試鎖相關(guān)的信息,這里同樣用這個工具來解決一個線上實際的死鎖案例,也是我們介紹的第一個兩條 SQL 就造成死鎖的情況。因為線上的表結(jié)構(gòu)比較復(fù)雜,做了一些簡化以后如下 CREATE TABLE `t3` ( `id` int(11) N
        推薦度:
        標簽: update 索引 死鎖
        • 熱門焦點

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 激情婷婷成人亚洲综合| 久久精品国产亚洲77777| 无码国产精品一区二区免费式影视| 免费国产成人午夜在线观看| 2020因为爱你带字幕免费观看全集| 很黄很色很刺激的视频免费| 亚洲同性男gay网站在线观看| 亚洲日本VA午夜在线影院| 中文在线免费视频| 免费观看无遮挡www的小视频| 全部免费毛片在线| 亚洲av无码不卡一区二区三区| 2020年亚洲天天爽天天噜| 中文字幕在线观看免费| 亚洲av无码精品网站| 91嫩草免费国产永久入口| 亚洲一区中文字幕在线电影网| 国产免费久久久久久无码| 日本免费一本天堂在线| 亚洲视频在线观看| 一级毛片免费播放视频| 男女做羞羞的事视频免费观看无遮挡| 亚洲免费网站在线观看| 国产福利免费在线观看| 亚洲国产视频久久| 青青草a免费线观a| 亚洲精品无码少妇30P| 国产亚洲精品成人AA片新蒲金| 国产精品亚洲精品| 无码欧精品亚洲日韩一区夜夜嗨| 亚洲黄网站wwwwww| 日韩免费人妻AV无码专区蜜桃 | 亚洲色婷婷综合久久| 亚洲AV无码精品国产成人| 一级女人18毛片免费| 污污的视频在线免费观看| 免费看少妇作爱视频| 亚洲18在线天美| 亚洲国产精品成人| 农村寡妇一级毛片免费看视频| 久久亚洲精品成人综合|