欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時(shí)間:2019年05月22日 15:23:56   作者:挖坑的張師傅  
前幾篇文章介紹了用源碼的方式來(lái)調(diào)試鎖相關(guān)的信息,這里同樣用這個(gè)工具來(lái)解決一個(gè)線上實(shí)際的死鎖案例,下面小編來(lái)簡(jiǎn)單介紹下

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

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語(yǔ)句如下

# 事務(wù)1:t1
update t3 set b = '' where a = "1";

# 事務(wù)2:t2
update t3 set b = '' where b = "2";


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

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

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

 

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

序號(hào) 索引 鎖類型
1 uk_a X
2 PRIMARY X
3 idx_b X

第二條語(yǔ)句

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

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

序號(hào) 索引 鎖類型
1 idx_b X
2 PRIMARY X
3 idx_b X

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

手動(dòng)是比較難模擬的,寫個(gè)代碼并發(fā)的去同時(shí)執(zhí)行那兩條 SQL 語(yǔ)句,馬上就出現(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 鎖

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

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • mysql?sock文件存儲(chǔ)了什么信息

    mysql?sock文件存儲(chǔ)了什么信息

    這篇文章主要為大家介紹了mysql?sock文件存儲(chǔ)了什么信息的內(nèi)容詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-07-07
  • MySQL字段自增自減的SQL語(yǔ)句示例介紹

    MySQL字段自增自減的SQL語(yǔ)句示例介紹

    MySQL的自增語(yǔ)句大家應(yīng)該都很熟悉,本文為大家介紹下MySQL字段自增自減的SQL語(yǔ)句,需要的朋友可以參考下
    2014-02-02
  • MySQL安裝常見(jiàn)報(bào)錯(cuò)處理方法總結(jié)大全

    MySQL安裝常見(jiàn)報(bào)錯(cuò)處理方法總結(jié)大全

    MySQL數(shù)據(jù)庫(kù)在安裝或卸載的過(guò)程中,常常會(huì)出現(xiàn)一些錯(cuò)誤,這是件讓我們頭疼的事,下面這篇文章主要給大家介紹了關(guān)于MySQL安裝常見(jiàn)報(bào)錯(cuò)處理方法的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-07-07
  • 關(guān)于JDBC與MySQL臨時(shí)表空間的深入解析

    關(guān)于JDBC與MySQL臨時(shí)表空間的深入解析

    這篇文章主要給大家介紹了關(guān)于JDBC與MySQL臨時(shí)表空間的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2018-09-09
  • Mysql 5.7 服務(wù)下載安裝圖文教程(經(jīng)典版)

    Mysql 5.7 服務(wù)下載安裝圖文教程(經(jīng)典版)

    MySQL 5.7在諸多方面都進(jìn)行了大幅的改進(jìn),主要在于安全性、靈活性、易用性、可用性和性能等幾個(gè)方面。這篇文章主要介紹了Mysql5.7服務(wù)下載安裝圖文教程(經(jīng)典版),需要的朋友可以參考下
    2016-09-09
  • MySQL數(shù)據(jù)庫(kù)安裝和Navicat for MySQL配合使用教程

    MySQL數(shù)據(jù)庫(kù)安裝和Navicat for MySQL配合使用教程

    MySQL是一個(gè)關(guān)系型數(shù)據(jù)庫(kù)管理系統(tǒng),由瑞典MySQL AB 公司開發(fā),目前屬于 Oracle 旗下公司。這篇文章主要介紹了MySQL數(shù)據(jù)庫(kù)安裝和Navicat for MySQL配合使用,需要的朋友可以參考下
    2019-06-06
  • linux下使用RPM安裝mysql5.7.17

    linux下使用RPM安裝mysql5.7.17

    這篇文章主要為大家詳細(xì)介紹了linux下使用RPM安裝mysql5.7.17的相關(guān)代碼,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-03-03
  • MySQL中設(shè)置服務(wù)器級(jí)別的默認(rèn)排序規(guī)則的方法

    MySQL中設(shè)置服務(wù)器級(jí)別的默認(rèn)排序規(guī)則的方法

    collation_server?是一個(gè)系統(tǒng)變量,它定義了服務(wù)器級(jí)別的默認(rèn)排序規(guī)則,本文主要介紹了MySQL中設(shè)置服務(wù)器級(jí)別的默認(rèn)排序規(guī)則的方法,具有一定的參考價(jià)值,感興趣的可以了解一下
    2024-08-08
  • MySQL?賬號(hào)密碼錯(cuò)誤終極解決方法

    MySQL?賬號(hào)密碼錯(cuò)誤終極解決方法

    這篇文章主要介紹了MySQL?賬號(hào)密碼錯(cuò)誤終極解決方法,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下
    2022-08-08
  • 阿里云Linux CentOS 7.2下自建MySQL的root密碼忘記的解決方法

    阿里云Linux CentOS 7.2下自建MySQL的root密碼忘記的解決方法

    這篇文章主要介紹了阿里云Linux CentOS 7.2下自建MySQL的root密碼忘記的解決方法,需要的朋友可以參考下
    2017-07-07

最新評(píng)論