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

Mysql?for?update導(dǎo)致大量行鎖的問題

 更新時(shí)間:2023年08月29日 09:57:30   作者:tingmailang  
這篇文章主要介紹了Mysql?for?update?導(dǎo)致大量行鎖的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

一、引言

最近同事的復(fù)盤會(huì)上提到自己for update一個(gè)不存在的where條件導(dǎo)致表鎖,然后產(chǎn)生大量的事務(wù)失敗和讀寫超時(shí),這時(shí)博主非常奇怪,因?yàn)殡m然網(wǎng)上許多博客寫Innodb的表鎖行鎖與鎖升級(jí),但是事實(shí)上這都是錯(cuò)誤的觀點(diǎn)。

二、分析

首先博主的環(huán)境是Mysql5.7,隔離級(jí)別是RC

博主為什么說這些都是錯(cuò)誤的觀點(diǎn)呢?

因?yàn)樵凇陡咝阅躆ysql》和《Innodb存儲(chǔ)引擎當(dāng)中》,非常明確的提出:

1、Innodb不存在鎖升級(jí)

所以不存在因?yàn)殒i的數(shù)據(jù)量大或者多表,導(dǎo)致行鎖升級(jí)成表鎖。

2、當(dāng)for update一個(gè)不存在的where條件時(shí)

Innodb加的是Record級(jí)別鎖

這一點(diǎn)可以通過驗(yàn)證得到

  • 不存在的where:
set autocommit = 0 ;
begin;
select * from t_aac_battery_compensate ?where gmt_create ?in ('2020-05-21 07:02:37') for update ;
  • 存在的where:
begin;
select * from t_aac_***??where gmt_create ?in ('2020-05-21 07:32:37') for update ;

然后執(zhí)行

select * from information_schema.INNODB_LOCKS il?

可以看到鎖

可以看到兩個(gè)事務(wù)加的都是行級(jí)別鎖。

可能有的同學(xué)會(huì)對(duì)鎖住的行數(shù)量和數(shù)據(jù)有疑惑,這里博主發(fā)現(xiàn)這兩個(gè)數(shù)值統(tǒng)計(jì)的方式是不準(zhǔn)的,包括在《Innodb存儲(chǔ)引擎》作者明確提出lock_data是不準(zhǔn)確的。

也有的同學(xué)疑惑他加行鎖為什么會(huì)阻塞其他讀寫,這里是innodb加了行鎖之后最后一起釋放,雖然不知道它這樣的設(shè)計(jì)是出于什么考慮。

3、Innodb如果在索引中找不到記錄

會(huì)在行數(shù)據(jù)進(jìn)行搜索,鎖住主鍵,而不是鎖表

所以一些博客說根據(jù)索引加不到鎖,innodb就會(huì)鎖全表,這是錯(cuò)誤的理解

只是可能在一些情況下他搜索行數(shù)據(jù)對(duì)主鍵加鎖的數(shù)量過多,之前也說了innodb加行鎖是最后一起釋放的,所以阻塞了其他讀寫

4、Innodb加鎖的方式是從上到下的

自動(dòng)加鎖只有表級(jí)別的意向鎖和行級(jí)鎖,表級(jí)別的意向鎖只會(huì)阻塞全表掃描

5、RR級(jí)別加鎖情況

上文都是基于博主線上環(huán)境配置,如果是RR隔離級(jí)別,還會(huì)有GapLock與行鎖進(jìn)行Next_keyLock算法加鎖,其實(shí)簡單說就是鎖住當(dāng)前B+樹種當(dāng)前索引到上一個(gè)索引之間(或當(dāng)前行到上一行)的間隔,防止在這個(gè)過程中有插入數(shù)據(jù),也就是防止幻讀。

但是這個(gè)情況不是絕對(duì)的,對(duì)于唯一索引,innodb會(huì)降低級(jí)別行級(jí)鎖,不會(huì)鎖住范圍

三、總結(jié)

通過以上分析得到結(jié)論:

1、RC級(jí)別下innodb都是行級(jí)鎖,表級(jí)的意向鎖只會(huì)阻塞全表掃描

2、innodb不存在鎖升級(jí)

3、innodb加不到索引會(huì)搜索行,對(duì)主鍵加鎖

4、當(dāng)for update一個(gè)不存在的where條件時(shí),Innodb加的是Record級(jí)別鎖

以上分析除了實(shí)際操作驗(yàn)證和權(quán)威書籍理解之外,博主與DBA也經(jīng)過深入探討,如果有異議歡迎討論。 另外希望各位同學(xué),多實(shí)際操作、多看權(quán)威書籍和源碼,對(duì)于網(wǎng)上的博客看一半信一半,要有自己的判斷,書籍和源碼的查看也要結(jié)合實(shí)際經(jīng)驗(yàn),因?yàn)槊總€(gè)人的腦回路是不一樣的,一不小心理解方向就可能歪了。

好了,這些僅為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • mysql子查詢(單行子查詢,多行子查詢,多列子查詢)

    mysql子查詢(單行子查詢,多行子查詢,多列子查詢)

    本文主要介紹了mysql子查詢(單行子查詢,多行子查詢,多列子查詢),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-06-06
  • 解決MySQL批量新增或修改時(shí)出現(xiàn)異常:Lock?wait?timeout?exceeded

    解決MySQL批量新增或修改時(shí)出現(xiàn)異常:Lock?wait?timeout?exceeded

    這篇文章主要給大家介紹了關(guān)于如何解決MySQL批量新增或修改時(shí)出現(xiàn)異常:Lock?wait?timeout?exceeded;try?restarting?transaction的相關(guān)資料,需要的朋友可以參考下
    2024-01-01
  • mysql 5.5 安裝配置簡單教程

    mysql 5.5 安裝配置簡單教程

    這篇文章主要為大家詳細(xì)介紹了mysql 5.5 安裝配置簡單教程,純文字描述mysql 5.5 安裝配置方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-11-11
  • mysql創(chuàng)建觸發(fā)器時(shí)報(bào)1064錯(cuò)誤問題及解決

    mysql創(chuàng)建觸發(fā)器時(shí)報(bào)1064錯(cuò)誤問題及解決

    這篇文章主要介紹了mysql創(chuàng)建觸發(fā)器時(shí)報(bào)1064錯(cuò)誤問題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-08-08
  • mysql中的general_log(查詢?nèi)罩?開啟和關(guān)閉

    mysql中的general_log(查詢?nèi)罩?開啟和關(guān)閉

    這篇文章主要介紹了mysql中的general_log(查詢?nèi)罩?開啟和關(guān)閉問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-11-11
  • 詳解數(shù)據(jù)庫語言中的null值

    詳解數(shù)據(jù)庫語言中的null值

    這篇文章主要詳解了數(shù)據(jù)庫語言中的null值,針對(duì)MySQL上的實(shí)例進(jìn)行講解,需要的朋友可以參考下
    2015-04-04
  • 詳解Mysql如何實(shí)現(xiàn)數(shù)據(jù)同步到Elasticsearch

    詳解Mysql如何實(shí)現(xiàn)數(shù)據(jù)同步到Elasticsearch

    要通過Elasticsearch實(shí)現(xiàn)數(shù)據(jù)檢索,首先要將Mysql中的數(shù)據(jù)導(dǎo)入Elasticsearch,并實(shí)現(xiàn)數(shù)據(jù)源與Elasticsearch數(shù)據(jù)同步,這里使用的數(shù)據(jù)源是Mysql數(shù)據(jù)庫。目前Mysql與Elasticsearch常用的同步機(jī)制大多是基于插件實(shí)現(xiàn)的,希望這篇文章能對(duì)大家有所幫助
    2021-11-11
  • CentOS下重置MySQL的root密碼的教程

    CentOS下重置MySQL的root密碼的教程

    這篇文章主要介紹了CentOS下重置MySQL的root密碼的教程,首先要擁有系統(tǒng)的root權(quán)限,最后還附屬了一個(gè)使用mysqladmin下的方法,需要的朋友可以參考下
    2015-11-11
  • mysql 5.5 開啟慢日志slow log的方法(log_slow_queries)

    mysql 5.5 開啟慢日志slow log的方法(log_slow_queries)

    MySQL中提供了一個(gè)慢查詢的日志記錄功能,可以把查詢SQL語句時(shí)間大于多少秒的語句寫入慢查詢?nèi)罩?,日常維護(hù)中可以通過慢查詢?nèi)罩镜挠涗浶畔⒖焖贉?zhǔn)確地判斷問題所在
    2016-05-05
  • MySQL?中的?SQL_MODE?設(shè)置方法ANSI_QUOTES?選項(xiàng)解析與應(yīng)用小結(jié)

    MySQL?中的?SQL_MODE?設(shè)置方法ANSI_QUOTES?選項(xiàng)解析與應(yīng)用小結(jié)

    sql_mode是?MySQL?中的一個(gè)系統(tǒng)變量,用于控制?SQL?語句的解析和執(zhí)行方式,它由多個(gè)選項(xiàng)組成,每個(gè)選項(xiàng)都可以獨(dú)立設(shè)置,以滿足不同的應(yīng)用場景需求,這篇文章主要介紹了MySQL?中的?SQL_MODE?設(shè)置:ANSI_QUOTES?選項(xiàng)解析與應(yīng)用
    2024-12-12

最新評(píng)論