国产一区二区精品-国产一区二区精品久-国产一区二区精品久久-国产一区二区精品久久91-免费毛片播放-免费毛片基地

千鋒教育-做有情懷、有良心、有品質的職業教育機構

手機站
千鋒教育

千鋒學習站 | 隨時隨地免費學

千鋒教育

掃一掃進入千鋒手機站

領取全套視頻
千鋒教育

關注千鋒學習站小程序
隨時隨地免費學習課程

當前位置:首頁  >  技術干貨  > HBase系列常見面試題匯總---HBase的MVCC多版本并發機制

HBase系列常見面試題匯總---HBase的MVCC多版本并發機制

來源:千鋒教育
發布人:syq
時間: 2022-08-12 10:52:44 1660272764

  MVCC(Multi Version Consistency Control),簡單地說,是一種通過數據的多版本來解決讀寫一致性問題的解決方案。我們知道 HBase 是會保留多版本的數據的,每次寫入都會產生一個新版本的數據,每次讀取都會默認讀最新版本的數據,那么 HBase 是在并發請求的場景下是怎么控制這些多版本的呢?下面是對HBase的MVCC多版本并發機制的具體介紹。

MVCC多版本并發機制

  如圖所示,LinkedList 每個元素里面有兩個屬性:

  writeNumber:即 Region 級別的事務 ID,每個客戶端請求都會分配一個事務 ID。

  completed: 數據寫入是否完成,初始狀態為 Flase,數據寫入成功后會更新為 True。

  客戶端寫入事務請求到達 Region,先寫入到 LinkedList 中,10 是當前事務的 ID,False 表示當前事務還在進行中,數據還不可讀。

  Client 將數據寫入 memstore 和 WAL ,寫入完成即可結束事務。

  將 completed 更新為 true,表示事務結束。

  同時,Client 會按順序遍歷 LinkedList 里的元素,若 completed:true 則將 readPoint 更新到這個位置,說明此處的數據是可讀的,遍歷到 completed:false 則停止。

  此時數據寫入還不會返回成功,即事務 10 還是不可讀的狀態,因為需要保證時序,client2 和 3 還在寫事務 7 和 9 沒有完成,當前可讀的數據只到事務 6 的位置。等到 client2 和 3 完成事務并將 readPoint 更新到 10,則事務 10 返回寫入成功,數據可讀。

  更多關于大數據培訓的問題,歡迎咨詢千鋒教育在線名師,如果想要了解我們的師資、課程、項目實操的話可以點擊咨詢課程顧問,獲取試聽資格來試聽我們的課程,在線零距離接觸千鋒教育大咖名師,讓你輕松從入門到精通。

  注:本文部分文字和圖片來源于網絡,如有侵權,請聯系刪除。版權歸原作者所有!

tags:
聲明:本站稿件版權均屬千鋒教育所有,未經許可不得擅自轉載。
10年以上業內強師集結,手把手帶你蛻變精英
請您保持通訊暢通,專屬學習老師24小時內將與您1V1溝通
免費領取
今日已有369人領取成功
劉同學 138****2860 剛剛成功領取
王同學 131****2015 剛剛成功領取
張同學 133****4652 剛剛成功領取
李同學 135****8607 剛剛成功領取
楊同學 132****5667 剛剛成功領取
岳同學 134****6652 剛剛成功領取
梁同學 157****2950 剛剛成功領取
劉同學 189****1015 剛剛成功領取
張同學 155****4678 剛剛成功領取
鄒同學 139****2907 剛剛成功領取
董同學 138****2867 剛剛成功領取
周同學 136****3602 剛剛成功領取
相關推薦HOT