亚洲视频二区_亚洲欧洲日本天天堂在线观看_日韩一区二区在线观看_中文字幕不卡一区

公告:魔扣目錄網(wǎng)為廣大站長提供免費(fèi)收錄網(wǎng)站服務(wù),提交前請做好本站友鏈:【 網(wǎng)站目錄:http://www.430618.com 】, 免友鏈快審服務(wù)(50元/站),

點(diǎn)擊這里在線咨詢客服
新站提交
  • 網(wǎng)站:51998
  • 待審:31
  • 小程序:12
  • 文章:1030137
  • 會員:747


 

我們在操作數(shù)據(jù)庫的時候,鎖的沖突是影響數(shù)據(jù)庫并發(fā)訪問性能的一個非常重要因素,從這一角度來說,鎖對于數(shù)據(jù)庫而言就顯得尤為重要。

今天分享MySQL相關(guān)的最全鎖@mikechen

01

MySQL鎖概述

相對其他數(shù)據(jù)庫而言,MySQL的鎖機(jī)制比較簡單,其最顯著的特點(diǎn)是不同的存儲引擎支持不同的鎖機(jī)制。

比如:

 

  1. MyISAM和MEMORY存儲引擎采用的是表級鎖;
  2. InnoDB存儲引擎既支持行級鎖,也支持表級鎖,但默認(rèn)情況下是采用行級鎖。

 

MySQL主要的兩種鎖的特性可大致歸納如下:


 

02

悲觀鎖 和 樂觀鎖

(1)悲觀鎖:顧名思義,就是很悲觀,每次去拿數(shù)據(jù)的時候都認(rèn)為別人會修改,所以每次在拿數(shù)據(jù)的時候都會上鎖,這樣別人想拿這個數(shù)據(jù)就會block直到它拿到鎖。

傳統(tǒng)的關(guān)系型數(shù)據(jù)庫里邊就用到了很多這種鎖機(jī)制,比如行鎖,表鎖等,讀鎖,寫鎖等,都是在做操作之前先上鎖。

(2)樂觀鎖:顧名思義,就是很樂觀,每次去拿數(shù)據(jù)的時候都認(rèn)為別人不會修改,所以不會上鎖,但是在更新的時候會判斷一下在此期間別人有沒有去更新這個數(shù)據(jù),可以使用版本號等機(jī)制。

樂觀鎖適用于多讀的應(yīng)用類型,這樣可以提高吞吐量,像數(shù)據(jù)庫如果提供類似于write_condition機(jī)制的其實(shí)都是提供的樂觀鎖。

(3)悲觀鎖 和 樂觀鎖的區(qū)別:

兩種鎖各有優(yōu)缺點(diǎn),不可認(rèn)為一種好于另一種,像樂觀鎖適用于寫比較少的情況下,即沖突真的很少發(fā)生的時候,這樣可以省去了鎖的開銷,加大了系統(tǒng)的整個吞吐量。但如果經(jīng)常產(chǎn)生沖突,上層應(yīng)用會不斷的進(jìn)行retry,這樣反倒是降低了性能,所以這種情況下用悲觀鎖就比較合適

03

共享鎖

共享鎖指的就是對于多個不同的事務(wù),對同一個資源共享同一個鎖。相當(dāng)于對于同一把門,它擁有多個鑰匙一樣。就像這樣,你家有一個大門,大門的鑰匙有好幾把,你有一把,你女朋友有一把,你們都可能通過這把鑰匙進(jìn)入你們家,這個就是所謂的共享鎖。

剛剛說了,對于悲觀鎖,一般數(shù)據(jù)庫已經(jīng)實(shí)現(xiàn)了,共享鎖也屬于悲觀鎖的一種,那么共享鎖在mysql中是通過什么命令來調(diào)用呢。通過查詢資料,了解到通過在執(zhí)行語句后面加上lock in share mode就代表對某些資源加上共享鎖了。

04

行鎖 和 表鎖

1.主要是針對鎖粒度劃分的,一般分為:行鎖、表鎖、庫鎖

(1)行鎖:訪問數(shù)據(jù)庫的時候,鎖定整個行數(shù)據(jù),防止并發(fā)錯誤。

(2)表鎖:訪問數(shù)據(jù)庫的時候,鎖定整個表數(shù)據(jù),防止并發(fā)錯誤。

2.行鎖 和 表鎖 的區(qū)別:

 

  • 表鎖:開銷小,加鎖快,不會出現(xiàn)死鎖;鎖定力度大,發(fā)生鎖沖突概率高,并發(fā)度最低
  • 行鎖:開銷大,加鎖慢,會出現(xiàn)死鎖;鎖定粒度小,發(fā)生鎖沖突的概率低,并發(fā)度高

 

表鎖和行鎖應(yīng)用場景

 

  • 表級鎖使用與并發(fā)性不高,以查詢?yōu)橹鳎倭扛碌膽?yīng)用,比如小型的web應(yīng)用;
  • 行級鎖適用于高并發(fā)環(huán)境下,對事務(wù)完整性要求較高的系統(tǒng),如在線事務(wù)處理系統(tǒng)。

 

05

什么時候使用表鎖

對于InnoDB表,在絕大部分情況下都應(yīng)該使用行級鎖,因?yàn)槭聞?wù)和行鎖往往是我們之所以選擇InnoDB表的理由。但在個別特殊事務(wù)中,也可以考慮使用表級鎖。

 

  • 第一種情況是:事務(wù)需要更新大部分或全部數(shù)據(jù),表又比較大,如果使用默認(rèn)的行鎖,不僅這個事務(wù)執(zhí)行效率低,而且可能造成其他事務(wù)長時間鎖等待和鎖沖突,這種情況下可以考慮使用表鎖來提高該事務(wù)的執(zhí)行速度。
  • 第二種情況是:事務(wù)涉及多個表,比較復(fù)雜,很可能引起死鎖,造成大量事務(wù)回滾。這種情況也可以考慮一次性鎖定事務(wù)涉及的表,從而避免死鎖、減少數(shù)據(jù)庫因事務(wù)回滾帶來的開銷。

 

當(dāng)然,應(yīng)用中這兩種事務(wù)不能太多,否則,就應(yīng)該考慮使用MyISAM表了。

-end-

阿里架構(gòu)師進(jìn)階從0到1全部合集(非常全面)


 

分享到:
標(biāo)簽:MySQL
用戶無頭像

網(wǎng)友整理

注冊時間:

網(wǎng)站:5 個   小程序:0 個  文章:12 篇

  • 51998

    網(wǎng)站

  • 12

    小程序

  • 1030137

    文章

  • 747

    會員

趕快注冊賬號,推廣您的網(wǎng)站吧!
最新入駐小程序

數(shù)獨(dú)大挑戰(zhàn)2018-06-03

數(shù)獨(dú)一種數(shù)學(xué)游戲,玩家需要根據(jù)9

答題星2018-06-03

您可以通過答題星輕松地創(chuàng)建試卷

全階人生考試2018-06-03

各種考試題,題庫,初中,高中,大學(xué)四六

運(yùn)動步數(shù)有氧達(dá)人2018-06-03

記錄運(yùn)動步數(shù),積累氧氣值。還可偷

每日養(yǎng)生app2018-06-03

每日養(yǎng)生,天天健康

體育訓(xùn)練成績評定2018-06-03

通用課目體育訓(xùn)練成績評定