【MySQL學(xué)習(xí)】No.6 全局鎖和表鎖

數(shù)據(jù)庫(kù)鎖設(shè)計(jì)的初衷是處理并發(fā)問題废士。作為多用戶共享的資源蚯姆,當(dāng)出現(xiàn)并發(fā)訪問的時(shí)候媒抠,數(shù)據(jù)庫(kù)需要合理地控制資源的訪問規(guī)則弟断。而鎖就是用來(lái)實(shí)現(xiàn)這些訪問規(guī)則的重要數(shù)據(jù)結(jié)構(gòu)。

根據(jù)加鎖的范圍趴生,MySQL 里面的鎖大致可以分成全局鎖阀趴、表級(jí)鎖和行鎖三類。

全局鎖

顧名思義冲秽,全局鎖就是對(duì)整個(gè)數(shù)據(jù)庫(kù)實(shí)例加鎖。MySQL 提供了一個(gè)加全局讀鎖的方法矩父,命令是 Flush tables with read lock (FTWRL)锉桑。當(dāng)你需要讓整個(gè)庫(kù)處于只讀狀態(tài)的時(shí)候,可以使用這個(gè)命令窍株,之后其他線程的以下語(yǔ)句會(huì)被阻塞:數(shù)據(jù)更新語(yǔ)句(數(shù)據(jù)的增刪改)民轴、數(shù)據(jù)定義語(yǔ)句(包括建表、修改表結(jié)構(gòu)等)和更新類事務(wù)的提交語(yǔ)句球订。

全局鎖的典型使用場(chǎng)景是后裸,做全庫(kù)邏輯備份。也就是把整庫(kù)每個(gè)表都 select 出來(lái)存成文本冒滩。

表級(jí)鎖

MySQL 里面表級(jí)別的鎖有兩種:一種是表鎖微驶,一種是元數(shù)據(jù)鎖(meta data lock,MDL)。

表鎖的語(yǔ)法是 lock tables … read/write因苹。與 FTWRL 類似苟耻,可以用 unlock tables 主動(dòng)釋放鎖,也可以在客戶端斷開的時(shí)候自動(dòng)釋放扶檐。需要注意凶杖,lock tables 語(yǔ)法除了會(huì)限制別的線程的讀寫外,也限定了本線程接下來(lái)的操作對(duì)象款筑。

舉個(gè)例子, 如果在某個(gè)線程 A 中執(zhí)行 lock tables t1 read, t2 write; 這個(gè)語(yǔ)句智蝠,則其他線程寫 t1、讀寫 t2 的語(yǔ)句都會(huì)被阻塞奈梳。同時(shí)杈湾,線程 A 在執(zhí)行 unlock tables 之前,也只能執(zhí)行讀 t1颈嚼、讀寫 t2 的操作毛秘。連寫 t1 都不允許,自然也不能訪問其他表阻课。

在還沒有出現(xiàn)更細(xì)粒度的鎖的時(shí)候叫挟,表鎖是最常用的處理并發(fā)的方式。而對(duì)于 InnoDB 這種支持行鎖的引擎限煞,一般不使用 lock tables 命令來(lái)控制并發(fā)抹恳,畢竟鎖住整個(gè)表的影響面還是太大。

另一類表級(jí)的鎖是 MDL(metadata lock)署驻。MDL 不需要顯式使用奋献,在訪問一個(gè)表的時(shí)候會(huì)被自動(dòng)加上。MDL 的作用是旺上,保證讀寫的正確性瓶蚂。

如何安全地給小表加字段?

首先我們要解決長(zhǎng)事務(wù)宣吱,事務(wù)不提交窃这,就會(huì)一直占著 MDL 鎖。在 MySQL 的 information_schema 庫(kù)的 innodb_trx 表中征候,你可以查到當(dāng)前執(zhí)行中的事務(wù)杭攻。如果你要做 DDL 變更的表剛好有長(zhǎng)事務(wù)在執(zhí)行,要考慮先暫停 DDL疤坝,或者 kill 掉這個(gè)長(zhǎng)事務(wù)兆解。

但考慮一下這個(gè)場(chǎng)景。如果你要變更的表是一個(gè)熱點(diǎn)表跑揉,雖然數(shù)據(jù)量不大锅睛,但是上面的請(qǐng)求很頻繁,而你不得不加個(gè)字段,你該怎么做呢衣撬?

這時(shí)候 kill 可能未必管用乖订,因?yàn)樾碌恼?qǐng)求馬上就來(lái)了。比較理想的機(jī)制是具练,在 alter table 語(yǔ)句里面設(shè)定等待時(shí)間乍构,如果在這個(gè)指定的等待時(shí)間里面能夠拿到 MDL 寫鎖最好,拿不到也不要阻塞后面的業(yè)務(wù)語(yǔ)句扛点,先放棄哥遮。之后開發(fā)人員或者 DBA 再通過重試命令重復(fù)這個(gè)過程。

MariaDB 已經(jīng)合并了 AliSQL 的這個(gè)功能陵究,所以這兩個(gè)開源分支目前都支持 DDL NOWAIT/WAIT n 這個(gè)語(yǔ)法眠饮。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市铜邮,隨后出現(xiàn)的幾起案子仪召,更是在濱河造成了極大的恐慌,老刑警劉巖松蒜,帶你破解...
    沈念sama閱讀 216,997評(píng)論 6 502
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件扔茅,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡秸苗,警方通過查閱死者的電腦和手機(jī)召娜,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,603評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)惊楼,“玉大人玖瘸,你說我怎么就攤上這事√戳” “怎么了雅倒?”我有些...
    開封第一講書人閱讀 163,359評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)弧可。 經(jīng)常有香客問我蔑匣,道長(zhǎng),這世上最難降的妖魔是什么侣诺? 我笑而不...
    開封第一講書人閱讀 58,309評(píng)論 1 292
  • 正文 為了忘掉前任殖演,我火速辦了婚禮氧秘,結(jié)果婚禮上年鸳,老公的妹妹穿的比我還像新娘。我一直安慰自己丸相,他們只是感情好搔确,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,346評(píng)論 6 390
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般膳算。 火紅的嫁衣襯著肌膚如雪座硕。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,258評(píng)論 1 300
  • 那天涕蜂,我揣著相機(jī)與錄音华匾,去河邊找鬼。 笑死机隙,一個(gè)胖子當(dāng)著我的面吹牛蜘拉,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播有鹿,決...
    沈念sama閱讀 40,122評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼旭旭,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了葱跋?” 一聲冷哼從身側(cè)響起持寄,我...
    開封第一講書人閱讀 38,970評(píng)論 0 275
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎娱俺,沒想到半個(gè)月后稍味,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,403評(píng)論 1 313
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡矢否,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,596評(píng)論 3 334
  • 正文 我和宋清朗相戀三年仲闽,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片僵朗。...
    茶點(diǎn)故事閱讀 39,769評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡赖欣,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出验庙,到底是詐尸還是另有隱情顶吮,我是刑警寧澤,帶...
    沈念sama閱讀 35,464評(píng)論 5 344
  • 正文 年R本政府宣布粪薛,位于F島的核電站悴了,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏违寿。R本人自食惡果不足惜湃交,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,075評(píng)論 3 327
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望藤巢。 院中可真熱鬧搞莺,春花似錦、人聲如沸掂咒。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,705評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至温圆,卻和暖如春挨摸,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背岁歉。 一陣腳步聲響...
    開封第一講書人閱讀 32,848評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工得运, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人锅移。 一個(gè)月前我還...
    沈念sama閱讀 47,831評(píng)論 2 370
  • 正文 我出身青樓澈圈,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親帆啃。 傳聞我的和親對(duì)象是個(gè)殘疾皇子瞬女,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,678評(píng)論 2 354

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