MySQL實(shí)戰(zhàn)45講 第六喇肋、七講筆記

數(shù)據(jù)庫的鎖

按范圍劃分,mysql里面的鎖大致分為全局鎖,表級鎖和行級鎖

全局鎖

Flush tables with read lock;

使用命令FTWRL后,整個(gè)庫處于只讀狀態(tài).

全局鎖的典型使用場景是,做全庫邏輯備份.
當(dāng) mysqldump 使用參數(shù)–single-transaction的時(shí)候甚侣,導(dǎo)數(shù)據(jù)之前就會啟動一個(gè)事務(wù)间学,來確保拿到一致性視圖。而由于 MVCC 的支持低葫,這個(gè)過程中數(shù)據(jù)是可以正常更新的.如果直接使用mysqldump的話,會導(dǎo)致加上全局鎖,業(yè)務(wù)基本不可用.
開啟事務(wù)(可重復(fù)讀)即可得到一致性視圖.但是需要引擎支持
當(dāng)引擎不支持的情況下,FTWRL就很有必要了.

表級鎖

表鎖一般是在數(shù)據(jù)庫引擎不支持行鎖的時(shí)候才會被用到的嘿悬。

表鎖

lock tables … read/write
unlock tables

元數(shù)據(jù)鎖

meta data lock,MDL

MDL 不需要顯式使用窒盐,在訪問一個(gè)表的時(shí)候會被自動加上钢拧。MDL 的作用是防止DDL和DML并發(fā)引發(fā)沖突.
事務(wù)中的 MDL 鎖,在語句執(zhí)行開始時(shí)申請葡粒,但是語句結(jié)束后并不會馬上釋放膜钓,而會等到整個(gè)事務(wù)提交后再釋放。

如何安全地給小表加字段颂斜?
資源首先我們要解決長事務(wù),事務(wù)不提交掌唾,就會一直占著 MDL 鎖忿磅。在 MySQL 的information_schema 庫的 innodb_trx 表中,你可以查到當(dāng)前執(zhí)行中的事務(wù)撩扒。如果你要
做 DDL 變更的表剛好有長事務(wù)在執(zhí)行,要考慮先暫停 DDL搓谆,或者 kill 掉這個(gè)長事務(wù)。

行級鎖

mysql的行鎖是在引擎層由各個(gè)引擎自己實(shí)現(xiàn)的.行級鎖即InnoDB的行鎖.

鎖的釋放

在事務(wù)當(dāng)中,行鎖在需要時(shí)加上,因?yàn)閮呻A段提交的緣故,在事務(wù)結(jié)束時(shí)釋放.所以在事務(wù)當(dāng)中,最可能造成鎖沖突,最可能影響并發(fā)度的鎖盡量往后放.

死鎖和死鎖檢測

事務(wù)互相等待資源釋放并持有資源時(shí),會出現(xiàn)死鎖.
死鎖解決方案:

  • 設(shè)置等待超時(shí),這個(gè)超時(shí)時(shí)間可以通過參數(shù)innodb_lock_wait_timeout 來設(shè)置黔寇。
  • 發(fā)起死鎖檢測斩萌,發(fā)現(xiàn)死鎖后,主動回滾死鎖鏈條中的某一個(gè)事務(wù)憋飞,讓其他事務(wù)得以繼續(xù)執(zhí)行將參數(shù) innodb_deadlock_detect 設(shè)置為 on姆吭,表示開啟這個(gè)邏輯
    熱點(diǎn)行更新解決方案:

控制訪問相同資源的并發(fā)事務(wù)量。

  • 關(guān)閉死鎖檢測,但要保證業(yè)務(wù)一定不會出現(xiàn)死鎖(有風(fēng)險(xiǎn))
  • 控制并發(fā)度,對于相同行的更新检眯,在進(jìn)入引擎之前排隊(duì).實(shí)現(xiàn)在數(shù)據(jù)庫服務(wù)端/中間件上.
  • 邏輯行拆分,一行拆為多行,然后進(jìn)行上層邏輯隨機(jī)命中物理行.
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末轰传,一起剝皮案震驚了整個(gè)濱河市瘪撇,隨后出現(xiàn)的幾起案子港庄,更是在濱河造成了極大的恐慌,老刑警劉巖渤涌,帶你破解...
    沈念sama閱讀 218,858評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件把还,死亡現(xiàn)場離奇詭異,居然都是意外死亡安皱,警方通過查閱死者的電腦和手機(jī)艇炎,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,372評論 3 395
  • 文/潘曉璐 我一進(jìn)店門缀踪,熙熙樓的掌柜王于貴愁眉苦臉地迎上來虹脯,“玉大人奏候,你說我怎么就攤上這事∠玖瘢” “怎么了蕉世?”我有些...
    開封第一講書人閱讀 165,282評論 0 356
  • 文/不壞的土叔 我叫張陵,是天一觀的道長奸例。 經(jīng)常有香客問我向楼,道長,這世上最難降的妖魔是什么逻卖? 我笑而不...
    開封第一講書人閱讀 58,842評論 1 295
  • 正文 為了忘掉前任评也,我火速辦了婚禮,結(jié)果婚禮上盗迟,老公的妹妹穿的比我還像新娘熙含。我一直安慰自己,他們只是感情好邮弹,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,857評論 6 392
  • 文/花漫 我一把揭開白布蚓聘。 她就那樣靜靜地躺著,像睡著了一般导饲。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上渣锦,一...
    開封第一講書人閱讀 51,679評論 1 305
  • 那天,我揣著相機(jī)與錄音型檀,去河邊找鬼听盖。 笑死,一個(gè)胖子當(dāng)著我的面吹牛皆看,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播无埃,決...
    沈念sama閱讀 40,406評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼嫉称,長吁一口氣:“原來是場噩夢啊……” “哼灵疮!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起震捣,我...
    開封第一講書人閱讀 39,311評論 0 276
  • 序言:老撾萬榮一對情侶失蹤伍派,失蹤者是張志新(化名)和其女友劉穎诉植,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體晾腔,經(jīng)...
    沈念sama閱讀 45,767評論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡灼擂,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,945評論 3 336
  • 正文 我和宋清朗相戀三年剔应,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片峻贮。...
    茶點(diǎn)故事閱讀 40,090評論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡纤控,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出刻撒,到底是詐尸還是另有隱情耿导,我是刑警寧澤,帶...
    沈念sama閱讀 35,785評論 5 346
  • 正文 年R本政府宣布捧搞,位于F島的核電站狮荔,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏殖氏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,420評論 3 331
  • 文/蒙蒙 一爵憎、第九天 我趴在偏房一處隱蔽的房頂上張望婚瓜。 院中可真熱鬧宝鼓,春花似錦巴刻、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,988評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽邑雅。三九已至妈经,卻和暖如春捧书,著一層夾襖步出監(jiān)牢的瞬間骤星,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,101評論 1 271
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留廊营,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,298評論 3 372
  • 正文 我出身青樓呐伞,卻偏偏與公主長得像,于是被迫代替她去往敵國和親慎式。 傳聞我的和親對象是個(gè)殘疾皇子伶氢,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,033評論 2 355

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