InnoDB存儲引擎行級鎖引起鎖爭用問題

在事務(wù)中執(zhí)行select…for update,update,delete會引起鎖叉袍,對于事務(wù)的修改涮毫,事務(wù)中會使用X鎖葡幸,X鎖是行級鎖,InnDB行鎖是通過給索引上的索引項加鎖實現(xiàn)的(只有通過索引條件檢索數(shù)據(jù)(即explain sql語句水慨,type=index或range),InnoDB才使用行級鎖敬扛,否則使用表鎖)

為了驗證這個晰洒,我做了一個小測驗

數(shù)據(jù)表t_bitfly:

CREATE TABLE `t_bitfly` (
  `id` bigint(20) NOT NULL DEFAULT '0',
  `value` varchar(32) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

session1:

start transaction;
Query OK, 0 rows affected (0.00 sec)

mysql> select * from t_bitfly where id < 4 for update;
+----+-------+
| id | value |
+----+-------+
|  1 | a     |
|  2 | b     |
|  3 | c     |
+----+-------+
3 rows in set (0.00 sec)

session2:

start transaction;
Query OK, 0 rows affected (0.00 sec)
mysql> select * from t_bitfly where id >= 4 for update;
select * from t_bitfly where id >= 4 for update;
ERROR 1205 (HY000): Lock wait timeout exceeded; try restarting transaction

出現(xiàn)死鎖

此刻我的心情

想不明白啊,不是應(yīng)該只鎖住<4的那幾行嗎

explain:

mysql> explain select * from t_bitfly where id < 4\G;
*************************** 1\. row ***************************
           id: 1
  select_type: SIMPLE
        table: t_bitfly
   partitions: NULL
         type: range
possible_keys: PRIMARY
          key: PRIMARY
      key_len: 8
          ref: NULL
         rows: 3
     filtered: 100.00
        Extra: Using where; Using index

type=range啥箭,使用上索引了啊谍珊,為什么,為什么急侥,不明白啊

我的心情

這個問題困擾自己好久砌滞,終于在今天晚上找到答案了,恍然大悟的感覺真的是賊爽

原因:在UPDATE坏怪、DELETE操作時贝润,MySQL不僅鎖定WHERE條件掃描過的所有索引記錄,而且會鎖定相鄰的鍵值陕悬,即所謂的next-key locking题暖。

繼續(xù)做測驗

session2:

start transaction;
    Query OK, 0 rows affected (0.00 sec)
    mysql> select * from t_bitfly where id > 5 for update;
    mysql> select * from t_bitfly where id > 4 for update;
+----+-------+
| id | value |
+----+-------+
|  5 | e     |
|  6 | f     |
|  7 | g     |
|  8 | h     |
|  9 | i     |
| 10 | j     |
| 11 | k     |
+----+-------+
7 rows in set (0.00 sec)

現(xiàn)在就不出現(xiàn)死鎖的情況下,因為此時沒有包括4

出現(xiàn)next-key有兩種情況捉超,一是上面的使用索引范圍胧卤,二是使用相等條件請求給一個不存在的記錄:
例如:

session 1:

mysql> start transaction;
Query OK, 0 rows affected (0.00 sec)

mysql> select * from t_bitfly where id = 17 for update;
Empty set (0.00 sec)

session 2:

mysql> start transaction;
Query OK, 0 rows affected (0.00 sec)

mysql> insert into t_bitfly values(17,'n');
ERROR 1205 (HY000): Lock wait timeout exceeded; try restarting transaction

一般情況下相等情況不會出現(xiàn)鎖爭用問題

使用next-key的目的:
1)解決幻讀
2)滿足mysql的復(fù)制和恢復(fù)

帶來的問題
造成嚴(yán)重的鎖等待

如何解決:
盡量避免使用范圍條件,使用相等條件來訪問和更新數(shù)據(jù)

行鎖的使用還需要注意的幾點拼岳,否則很有可能會在執(zhí)行的時候出現(xiàn)死鎖或獲取不到鎖的情況(比如我遇到的):

1)在MySQL中枝誊,行級鎖并不是直接鎖記錄,而是鎖索引惜纸。

2)索引分為主鍵索引和非主鍵索引兩種叶撒,如果一條sql語句操作了主鍵索引绝骚,MySQL就會鎖定這條主鍵索引;如果一條語句操作了非主鍵索引(自定義索引+主鍵)祠够,MySQL會先鎖定該非主鍵索引压汪,再鎖定相關(guān)的主鍵索引

3)當(dāng)兩個事務(wù)同時執(zhí)行,一個鎖住了主鍵索引古瓤,在等待其他相關(guān)索引止剖。另一個鎖定了非主鍵索引,在等待主鍵索引落君。這樣就會發(fā)生死鎖

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末穿香,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子绎速,更是在濱河造成了極大的恐慌皮获,老刑警劉巖,帶你破解...
    沈念sama閱讀 222,252評論 6 516
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件纹冤,死亡現(xiàn)場離奇詭異洒宝,居然都是意外死亡,警方通過查閱死者的電腦和手機赵哲,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,886評論 3 399
  • 文/潘曉璐 我一進(jìn)店門待德,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人枫夺,你說我怎么就攤上這事将宪。” “怎么了橡庞?”我有些...
    開封第一講書人閱讀 168,814評論 0 361
  • 文/不壞的土叔 我叫張陵较坛,是天一觀的道長。 經(jīng)常有香客問我扒最,道長丑勤,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 59,869評論 1 299
  • 正文 為了忘掉前任吧趣,我火速辦了婚禮法竞,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘强挫。我一直安慰自己岔霸,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 68,888評論 6 398
  • 文/花漫 我一把揭開白布俯渤。 她就那樣靜靜地躺著呆细,像睡著了一般。 火紅的嫁衣襯著肌膚如雪八匠。 梳的紋絲不亂的頭發(fā)上絮爷,一...
    開封第一講書人閱讀 52,475評論 1 312
  • 那天趴酣,我揣著相機與錄音,去河邊找鬼坑夯。 笑死岖寞,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的渊涝。 我是一名探鬼主播慎璧,決...
    沈念sama閱讀 41,010評論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼床嫌,長吁一口氣:“原來是場噩夢啊……” “哼跨释!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起厌处,我...
    開封第一講書人閱讀 39,924評論 0 277
  • 序言:老撾萬榮一對情侶失蹤鳖谈,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后阔涉,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體缆娃,經(jīng)...
    沈念sama閱讀 46,469評論 1 319
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,552評論 3 342
  • 正文 我和宋清朗相戀三年瑰排,在試婚紗的時候發(fā)現(xiàn)自己被綠了贯要。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,680評論 1 353
  • 序言:一個原本活蹦亂跳的男人離奇死亡椭住,死狀恐怖崇渗,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情京郑,我是刑警寧澤宅广,帶...
    沈念sama閱讀 36,362評論 5 351
  • 正文 年R本政府宣布,位于F島的核電站些举,受9級特大地震影響跟狱,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜户魏,卻給世界環(huán)境...
    茶點故事閱讀 42,037評論 3 335
  • 文/蒙蒙 一驶臊、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧叼丑,春花似錦关翎、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,519評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至症副,卻和暖如春店雅,著一層夾襖步出監(jiān)牢的瞬間政基,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,621評論 1 274
  • 我被黑心中介騙來泰國打工闹啦, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留沮明,地道東北人。 一個月前我還...
    沈念sama閱讀 49,099評論 3 378
  • 正文 我出身青樓窍奋,卻偏偏與公主長得像荐健,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子琳袄,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,691評論 2 361

推薦閱讀更多精彩內(nèi)容