中文字幕av高清_国产视频一二区_男女羞羞羞视频午夜视频_成人精品一区_欧美色视_在线视频这里只有精品

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

手機站
千鋒教育

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

千鋒教育

掃一掃進入千鋒手機站

領取全套視頻
千鋒教育

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

當前位置:首頁  >  技術干貨  > OceanBase的memtable設計成key為主鍵,value為行操作鏈表的目的是什么?

OceanBase的memtable設計成key為主鍵,value為行操作鏈表的目的是什么?

來源:千鋒教育
發布人:xqq
時間: 2023-10-13 08:30:34 1697157034

一、OceanBase的memtable設計成key為主鍵,value為行操作鏈表的目的

這是MVCC多版本并發控制的一種實現方式,寫不阻塞讀,并且讀可以讀到一個快照版本。實現MVCC可以有多種方法,下面我解釋一下幾種可能的實現方法,并分析一下各方法的優劣

B+tree是索引,可以通過一行的key,索引到其value,索引還可以是其它的,比如Rocksdb和MemSQL用的是skiplist,還可以是Hashtable,還有一些新的數據結構微軟Hekaton用的bw-tree,HyPer用的adaptive radix tree等。B+tree是非常合適的,對范圍查詢和點查詢都不錯,對于CPU Cache非常友好,可以做到很高的性能,至于用skiplist的數據庫,看了一他們選擇這個的理由,文檔里基本都是說因為實現起來比較簡單,B+tree實現起來太復雜了。不過OceanBase的前輩們把內存B+tree實現的非常好,可以看到實力非常強,不需要因為某些東西簡單而去選擇用那個東西。

下面說一下幾種實現方法,主要說的是MVCC,就不說B+tree了

1. 完整數據直接存Row里,新版本在前

讀的時候,有一個snapshot version,比如是7,就需要找到名列前茅個小于7的版本,v=6的那個數據

優點:如果更新不頻繁,大部分查詢所需的數據版本都是最新的,通過索引找到某一行,直接通過指針就可以找到所需數據。通過指針就是一次內存的隨機訪問,100ns,當然還有其它處理數據的開銷。

缺點:更新數據的時候,需要申請一塊新的內存空間存儲數據,由于它需要被放鏈表首位置,索引就需要指向它,因此需要更新一下索引的指針,使其指向新的數據。

2. 完整數據直接存Row里,老版本在前

優點:更新的時候,直接插到鏈表的最后就好了,不需要再更新索引的指針

缺點:查詢的時候,可能需要順著鏈表找很多結點才能找到所需版本的數據,而每一次都是一次內存隨機訪問,需要(n*100)ns。

3. 更新數據存在Node里,然后通過Row指向Node,定期做壓縮

優點:更新的時候,直接插入Row的指針指向的名列前茅個位置就好了,而且不需要像第1種方法那樣更新索引。另一個優點是,由于只存儲增量數據,能節省很多內存,尤其是當一個表的列數非常多的時候

缺點:查詢的時候,就算是需要查詢最新的版本,也可能需要遍歷多個node才能得到完整的數據。不過當更新過多時,可以通過壓縮,將多個更新合并成完整數據,存到一個新的node中,一定程度上緩解這個問題

4. 數據存到一塊連續的內存中

前面幾種方法都是,當插入一行新的數據時,申請一塊內存,存數據,或者存更新node,這會導致做scan的時候比較慢。因為做scan的時候,需要通過索引中的指針才能找到數據,做scan是先對索引進行scan,再找到相應的數據,而每一次內存隨機訪問是100ns,也就是每秒掃描的數據量不可能超過1s/100ns=1000萬

所以可以申請一塊大內存,類似一個存struct的數組,然后把每一行存到這個數組里,定長數據直接存,變長數據用指針,對于小字符串,可以做一個優化,將字符串分成2部分,前面小的一部分可以直接存數據里,然后通過指針指向另一部分

至于多版本和增量數據,可以按照前面幾種方法做選擇

做點查詢的時候,通過索引查,做scan的時候,看查詢的數據情況,當數據量大時,直接scan數組是更快的,數據量小時,仍然通過索引做范圍查找

優點:一些情況下,scan的性能更高

缺點:由于是原地更改row里的數據,讀寫的時候都需要加鎖(latch),更新多的時候,對讀不友好

延伸閱讀:

二、網絡附加存儲(NAS)

NAS指Network Area Storage,即網絡附加存儲。它一般是將本地的存儲空間共享給其他主機使用,一般通過C/S架構實現通信。它實現的是文件級別的共享,計算機通常將共享的設別識別為一個文件系統,其文件服務器會管理鎖以實現并發訪問。網絡文件系統,以文件模塊的形式進行共享,工作在應用層上,常見的NAS有NFS和CIFS(FTP)。

聲明:本站稿件版權均屬千鋒教育所有,未經許可不得擅自轉載。
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
主站蜘蛛池模板: 免费a爱片猛猛 | 久国久产久精永久网页 | 精品九九九 | 妞干网在线观看 | 天天草天天草 | 国产1级片 | 四虎影片| 暖暖视频日韩欧美在线观看 | 久久精品亚洲 | 激情com| 成人一区av | 国产黄色免费小视频 | 超级碰在线视频 | 欧美一级免费在线观看 | 青娱乐在线播放 | 国产在线国偷精品产拍免费观看 | 日本成人中文字幕 | 亚洲精品视频在线播放 | 99福利视频| 99精品视频在线免费观看 | 99riav国产一区二区三区 | 日韩中文字幕免费观看 | 天天躁日日躁狠狠很躁 | 黑人xxx视频 | 成年无码av片在线 | 在线观看毛片视频 | 国产精品三级在线 | 久久草视频 | 99精品国产高清在线观看 | 日韩福利在线观看 | 免费在线观看毛片网站 | 一区二区三区在线 | 欧美日韩黄 | 国产精品久久久一区二区三区 | 色干综合| 一呦二呦三呦国产精品 | 大胆裸体gogo毛片免费看 | 欧美aaaaa | 国产精品二区一区二区aⅴ污介绍 | 色欧美片视频在线观看 | 天天干人人 |