精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

詳解 ZooKeeper 數據持久化

開發 前端
們通過之前的文章有介紹過,小S(Sync)負責對辦事處的數據進行歸檔,所以今天他就是我們的主角,讓我們一起深入了解他的日常工作吧!

[[388266]]

本文轉載自微信公眾號「HelloGitHub」,作者HelloGitHub。轉載本文請聯系HelloGitHub公眾號。

Hi,這里是 HelloGitHub 推出的 HelloZooKeeper 系列,免費開源、有趣、入門級的 ZooKeeper 教程,面向有編程基礎的新手。

項目地址:https://github.com/HelloGitHub-Team/HelloZooKeeper

前一篇文章我們介紹了 ZK 是如何進行選舉的,這篇我們開始學習 ZK 是如何將數據持久化到磁盤中的。

一、優秀員工小S(Sync)

我們通過之前的文章有介紹過,小S(Sync)負責對辦事處的數據進行歸檔,所以今天他就是我們的主角,讓我們一起深入了解他的日常工作吧

為了喚醒大家的遠古記憶,我放一張之前的

今天我們會重點講一下圖中的藍色部分,不過在此之前還是得先從整體架構上介紹下 ZK 的數據管理,ZK 的數據大致是分為了兩部分,一個是內存,一個就是磁盤文件。

1.1 內存

雖然今天我們的主角是磁盤文件,但是內存還是稍微再提一下下,幫助大家記憶的同時也能有一個比較全面的視角去認知 ZK 整體的數據管理。

ZK 在內存中的存儲就是之前故事中有提到的兩個賬本:小紅本和小黃本。如果排除作為回調通知記錄的小黃本,那 ZK 的內存中就是小紅本對應的哈希表而已,但是小黃本中的數據依然非常重要,所以需要將兩者作為整體一起看待,以及之前我有說過小F(Final)掌管了這兩個賬本,作為業務處理的最后一個負責人,小S(Sync) 從時間上來說是優先于小F(Final)先處理的,所以 ZK 的設計是優先將數據存入磁盤,再去修改內存中的數據保證盡可能的提升數據的可靠性。下面我們繼續了解磁盤文件(還真就提一下下!)

1.2 磁盤文件

ZK 的開發者給 ZK 設計了兩種磁盤文件,對應的路徑分別是 zoo.cfg 配置中的 dataDir 和 dataLogDir 這兩項目錄的配置。為了之后的描述清楚,我給這兩種磁盤文件起了名字:dataDir 對應 snapshot,dataLogDir 對應 log,log 就是的是小S(Sync)工作中的歸檔,snapshot 就是的是小S(Sync)工作中的快照。

log 是負責順序記錄每一個寫請求到文件,snapshot 則是直接將整個內存對象持久化至文件中。假設我現在 zoo.cfg 的配置是這樣:

  1. dataDir=/tmp/zookeeper/snapshot 
  2. dataLogDir=/tmp/zookeeper/log 

當 ZK 啟動后會基于上面兩個路徑繼續創建 version-2 子路徑,之后的文件都會在該子路徑下創建

  1. /tmp 
  2. └── zookeeper 
  3.     ├── snapshot 
  4.       └── version-2 
  5.         └── ... 
  6.     └── log 
  7.       └── version-2 
  8.         └── ... 

二、文件的創建和寫入

兩種文件分別是在什么時候被寫入磁盤的呢?寫入的內容又是哪些呢?我們接下來對兩種文件一一進行分析。

2.1 log 文件

log 文件名的格式是這樣 log.{zxid} zxid 對應當時創建該文件時的最大 zxid,假設現在創建時 zxid 為 0,那目錄結構會是這樣:

  1. /tmp 
  2. └── zookeeper 
  3.     └── log 
  4.       └── version-2 
  5.         └── log.0 

這個 log.0 文件創建的時機你也可以簡單的理解為當服務端收到第一個寫請求的時候,而且當創建完成后,并不能直接將數據寫入,而是要先寫一些文件頭的字段,比如大名鼎鼎的魔數,版本號等元信息。

而 log 文件的魔數是 ZKLG(4 個字節),版本號固定為 2(4 個字節),還要記錄一個 dbId 固定為 0(8 個字節) (當前沒用,可能之后會派用處吧),所以前 16 個字節是固定這樣的:

  1. Z K L G        2                 0 
  2. A4B4C47 00000002 00000000 00000000 

那之后的業務數據是如何記錄的呢?

每一個寫請求都可以分為四個部分:校驗和、請求頭、請求數據、簽名,校驗和是通過后面三個字段計算出來的,小S每次收到寫請求后都會按照這樣的順序將對應請求的四個字段寫入 log 文件,由于不同的業務請求數據不固定,而且數據長度也比較大,這里就不給大家展示具體的值(如果大家想要知道這硬核的存儲過程,不妨給我留言,我以后單獨做下,嘗試逐個字節解釋)

然后是 zookeeper.txnLogSizeLimitInKb 這個環境變量配置,默認是 -1,這個配置限制了 log 單個文件大小(單位是 KB),每次小S(Sync)歸檔的時候(圖中右下角粉色部分“是否歸檔”),將數據統一刷到磁盤后,如果用戶手動配置了該參數,就會檢查當前 log 文件大小是否超過了該參數大小,如果超過了就會進行 rollLog,相當于下一次的寫請求會創建一個新的 log 文件。除此之外,當小S(Sync)每次快照的時候會強制執行一次 rollLog。

2.2 snapshot 文件

snapshot 文件名的格式是這樣 snapshot.{zxid} zxid 對應當是創建該文件時的最大 zxid,假設現在創建是最大 zxid 是 0,那目錄結構會是這樣:

  1. /tmp 
  2. └── zookeeper 
  3.     └── snapshot 
  4.       └── version-2 
  5.         └── snapshot.0 

而關于是否快照(圖中中間區域粉色部分“是否快照”),之前有簡單介紹過是和隨機數有關,這次我們深入了解下。

首先有兩個配置 zookeeper.snapCount (默認 100000)和 zookeeper.snapSizeLimitInKb(默認 4194304 單位是KB,相當于 4 GB)在啟動后會基于這兩個配置分別生成兩個隨機數,假設上述的配置是按照默認的設置,這兩個隨機數的范圍就是:

  1. randRoll = [0, 50000] 
  2. randSize = [0, 4194304 * 1024 / 2] 

可以簡單的認為就是上述兩個配置的一半之內的隨機數,至于 randSize 為什么要乘以 1024 因為最終文件計算大小是以 byte 作為單位的。

而是否快照就是取決于上面兩個隨機數,有兩個條件:

  • 當前寫請求的數量達到了 zookeeper.snapCount 的一半并加上 randRoll 的數量
  • 當前 log 文件的大小達到了 zookeeper.snapSizeLimitInKb 的一半并加上 randSize 的大小

上述條件滿足任意一個條件后就會重置上面的兩個隨機數,并開始生成快照,生成快照這個過程是啟動一個子線程去創建的。

snapshot 和 log 還有個不同的地方就是,snapshot 文件 ZK 提供了三種不同的壓縮實現,GZIP、SNAPPY、CHECKED,通過 zookeeper.snapshot.compression.method 進行配置,默認是 CHECKED,就是原始按照字節順序寫入,另外兩個這里就不展開了。那我們接下來看看 snapshot 文件是怎么記的吧。

和 log 文件一樣,也要先記一些文件的頭部字段,而 snapshot 文件的魔數是 ZKSN(4 個字節),版本號固定為 2(4 個字節),還要記錄一個 dbId 固定為 -1(8 個字節) (當前沒用,可能之后會派用處吧),所以前 16 個字節是固定這樣的:

  1. Z K S N        2         -1 
  2. 5A4B534E 00000002 FFFFFFFF FFFFFFFF 

然后緊跟其后的部分客戶端的會話信息,客戶端的數量,然后循環記錄每一個客戶端的 sessionId、超時時間,然后是小紅本里的所有信息了包括但不限于 ACL,節點的統計數據,節點的數據,子節點的信息等。最后一部分就是校驗和和簽名。和 log 一樣,如果大家有興趣的話,我之后單獨再做一篇逐個字節講解的。

三、從文件中恢復

如果只是單單存文件,那這文件也沒什么用,所以文件另一個重要用途就是幫助 ZK 恢復服務端的信息。

在 ZK 啟動的時候就會嘗試讀取 dataDir 和 dataLogDir 這兩個目錄下的文件,假設在這兩個路徑下的文件是:

  1. /tmp 
  2. └── zookeeper 
  3.     ├── snapshot 
  4.       └── version-2 
  5.         └── snapshot.5 
  6.         └── snapshot.37 
  7.         └── snapshot.100 
  8.     └── log 
  9.       └── version-2 
  10.         └── log.0 
  11.         └── log.6 
  12.         └── log.38 
  13.         └── log.90 
  14.         └── log.108 

我這里例子中的文件名的后綴數字是我隨便舉例只是為了說明恢復的過程,實際未必是這樣,切記。

現在 ZK 服務端啟動后,會先從 snapshot 的目錄中找到 zxid 最大的那個文件,然后根據它的內容恢復小紅本

恢復完后就會去 log 文件目錄下尋找所有比 100 要大的 log 文件以及比 100 要略小一點的 log 文件,本例子中就是 log.90 和 log.108 這兩個文件。

你可能會問為什么要找小于 100 的 log.90 這個文件呢?因為文件名中的 90 只是說明這個文件建立的時候,最大的 zxid 是 90,但是文件中記錄的寫請求是很有可能會大于 100 的,所以 log.90 也需要被找到。

然后就是從 log.90 這個文件開始恢復,先從 zxid 比 100 大的寫請求開始讀取并執行該寫請求,然后繼續讀取 log.108,等待所有符合條件的 log 文件讀取后,整個 ZK 的數據就恢復完成了。

四、總結

今天我們介紹了關于 ZK 持久化的知識:

ZK 會持久化到磁盤的文件有兩種:log 和 snapshot

log 負責記錄每一個寫請求

snapshot 負責對當前整個內存數據進行快照

恢復數據的時候,會先讀取最新的 snapshot 文件

然后在根據 snapshot 最大的 zxid 去搜索符合條件的 log 文件,再通過逐條讀取寫請求來恢復剩余的數據

今天的內容還是比較簡單的,為我們下一篇文章打好了基礎~下一篇我們開始介紹之前選舉中沒有介紹的內容:選舉完成后,Follower 和 Observer 是如何同 Leader 同步數據的?

 

責任編輯:武曉燕 來源: HelloGitHub
相關推薦

2011-08-17 15:19:38

iPhone應用數據

2019-05-15 09:44:33

數據Redis持久化

2019-05-15 09:04:47

Redis數據存儲數據

2024-09-29 09:25:53

2023-12-14 07:30:04

PicklePython模塊

2011-08-25 14:26:40

LUA數據文件

2023-08-17 16:17:00

Docker前端

2019-05-17 08:55:49

RedisRDBAOF

2024-04-03 15:40:14

WebSocketWeb應用Spring

2024-04-25 16:17:53

SentinelNacos數據源

2011-07-07 15:45:45

iPhone SQLite 數據

2013-09-12 14:56:02

iOS持久化

2024-09-06 17:49:46

2018-12-14 09:48:23

Redis數據故障

2017-09-21 08:16:33

數據存儲環境

2022-08-30 10:15:27

Kubernetes數據持久化管理

2011-06-07 17:16:47

iPhone 數據

2020-01-06 14:54:31

RDBAOFRedis

2024-03-26 00:03:08

Redis數據RDB

2023-11-26 09:06:46

點贊
收藏

51CTO技術棧公眾號

国产在线视频精品一区| 红杏一区二区三区| 国产精品电影院| av在线不卡一区| 日韩特级黄色片| 久久福利影院| 亚洲第一天堂av| 免费在线观看毛片网站| 黄视频网站在线| 成人免费黄色在线| 国产精品国产三级国产aⅴ浪潮| 国产人与禽zoz0性伦| 福利在线一区| 欧美日韩一区三区四区| 日本五级黄色片| 国产三级在线免费| 国产精品123| 欧美重口另类videos人妖| 国产性生活大片| 久久91麻豆精品一区| 日韩一区二区免费在线观看| 欧洲av无码放荡人妇网站| 毛片在线看网站| 久久嫩草精品久久久久| 99三级在线| 亚洲视频中文字幕在线观看| 国产视频一区在线观看一区免费| 日韩在线欧美在线| 性欧美丰满熟妇xxxx性仙踪林| 国产精品麻豆| 欧美天天综合网| 99爱视频在线| 不卡av免费观看| 亚洲乱码中文字幕| 一区二区三区四区视频在线观看 | 欧美精品自拍偷拍动漫精品| 免费无码不卡视频在线观看| 在线电影福利片| 国产精品久久久久久福利一牛影视 | 乱亲女秽乱长久久久| 精品无码在线观看| 亚洲国产精品嫩草影院久久av| 欧美成人猛片aaaaaaa| 亚洲精品第三页| 超碰这里只有精品| 日本韩国精品在线| 播放灌醉水嫩大学生国内精品| 毛片在线导航| 亚洲高清中文字幕| 精品人妻人人做人人爽| 久草中文在线| 综合av第一页| 熟妇熟女乱妇乱女网站| 男人的天堂在线视频免费观看 | 亚洲日本va中文字幕| 正在播放一区二区| 日韩av一卡二卡三卡| 国产一区精品福利| 欧美日韩小视频| 色播五月激情五月| 99视频有精品高清视频| 欧美精品乱码久久久久久按摩 | 24小时成人在线视频| 欧美日韩一级片网站| av网站在线不卡| 欧美韩国日本| 欧美一区二区三区小说| 亚洲妇女无套内射精| 91嫩草精品| 亚洲国产一区二区三区四区| 中文精品在线观看| 国产一区二区欧美| 在线观看亚洲区| 国产免费美女视频| 亚洲一级黄色| 欧美又大又硬又粗bbbbb| 国产一区二区视频免费| 美女视频网站黄色亚洲| 亚洲最大的av网站| 少妇精品视频一区二区| 久久蜜臀精品av| 亚洲精品国产精品久久| caoporm免费视频在线| 亚洲一区二区在线免费观看视频| 99视频在线免费播放| 欧美aaa视频| 欧美一卡二卡三卡| 黄色三级视频在线播放| 97人人澡人人爽91综合色| 亚洲成人黄色网址| 青娱乐国产视频| 欧美精选一区| 国产成人极品视频| 精品久久久久久亚洲综合网站| 99久久国产综合精品麻豆| 日韩欧美精品在线不卡| 亚洲小说区图片区都市| 欧美三级xxx| 国产永久免费网站| 精品亚洲自拍| 久久精品中文字幕| 日本熟妇一区二区| 精品在线免费视频| 久久伊人一区| yellow91字幕网在线| 欧美视频在线免费| 国产精品久久久久久久av福利| 精品国产导航| 久久国产精品视频| 波多野结衣视频观看| 国产99久久精品| 亚洲国产日韩欧美| 国产一二三在线| 91精品国产综合久久久久久 | 午夜精品一区二区三| 久久精品欧美一区二区三区不卡| 大片在线观看网站免费收看| 偷拍中文亚洲欧美动漫| 精品国产电影一区二区| 最新av电影网站| 日韩精品成人一区二区在线| 国产伦精品一区二区三毛| 黄网站免费在线观看| 日本精品一级二级| 一起草在线视频| 欧美精品aa| 91免费的视频在线播放| www在线免费观看| 欧美性生交xxxxxdddd| 99久久久无码国产精品性波多 | 另类少妇人与禽zozz0性伦| 国产寡妇亲子伦一区二区三区四区| 国产成a人亚洲精| 一区二区三区观看| 国产69精品久久久久9999人| 亚洲欧美国产日韩天堂区| 久久草视频在线| 国产91精品久久久久久久网曝门| 黄色录像特级片| 亚洲国产天堂| 久久精品2019中文字幕| 国产一区二区三区成人| 国产精品久久久久久久久久久免费看 | 另类综合日韩欧美亚洲| 日韩欧美视频一区二区| 成人欧美大片| 亚洲区免费影片| 精品国产乱子伦| 久久久亚洲精品一区二区三区 | 青青视频免费在线| 99精品美女视频在线观看热舞| 中文字幕久久亚洲| 亚洲天堂avav| 最新久久zyz资源站| 天天做天天干天天操| 91精品天堂福利在线观看| 亚洲v日韩v综合v精品v| 污污网站在线看| 亚洲成人1234| 在线观看黄网站| 久久久一区二区三区| 色免费在线视频| 亚洲蜜桃视频| 国产精品夜夜夜一区二区三区尤| av2020不卡| 亚洲区一区二区| 一本久道久久综合无码中文| 亚洲日本护士毛茸茸| av漫画在线观看| 西西人体一区二区| 日韩av电影免费播放| 综合久草视频| 久久人人爽国产| 美女毛片在线看| 欧美日韩黄色影视| 欧美色图亚洲天堂| 91免费精品国自产拍在线不卡| 国产精品少妇在线视频| 日韩在线观看一区| av日韩免费电影| 日本久久免费| 久久国产精彩视频| 亚洲人视频在线观看| 欧美色网一区二区| 久久久久黄色片| 国产欧美日韩精品在线| 中文字幕日韩久久| 国产日韩欧美三区| 一本久久a久久精品vr综合| 亚洲成人影音| 国产精品成人va在线观看| v片在线观看| 亚洲色图五月天| 国产熟女精品视频| 色综合一个色综合| 极品久久久久久| 久久久久久久久蜜桃| 先锋资源在线视频| 久久中文精品| 国产精彩视频一区二区| 日韩在线高清| 欧美国产视频在线观看| 日韩精品一区国产| 国产精品久久久av| cao在线视频| 久久亚洲国产精品成人av秋霞| 天堂在线视频观看| 777午夜精品免费视频| 在线观看日韩中文字幕| 亚洲免费av网站| 在线国产视频一区| 不卡影院免费观看| 国产精品久久久久久久99| 视频在线观看一区| 日韩xxxx视频| 在线精品视频在线观看高清| 午夜精品福利一区二区| 日韩精品丝袜美腿| 成人黄色在线免费观看| 欧美成人黄色| 国产精品黄色影片导航在线观看| 999av小视频在线| 欧美噜噜久久久xxx| 免费高清在线观看| 亚洲天堂第一页| 亚洲av成人无码久久精品老人| 日韩一区二区三区av| 91theporn国产在线观看| 在线观看日韩av先锋影音电影院| 国产第一页在线播放| 一区二区三区中文字幕| 成人自拍小视频| 国产精品久久久久久久久图文区| 国产精品成人一区二区三区电影毛片| 成人一区二区三区视频在线观看| 国产免费中文字幕| 久久成人免费电影| 国产视频手机在线播放| 日韩avvvv在线播放| 精品国产成人av在线免| 国产精品毛片在线| 黄色动漫网站入口| 在线一区免费观看| 男人操女人逼免费视频| 亚洲精品社区| a在线视频观看| 亚洲永久网站| 欧美两根一起进3p做受视频| 天堂成人免费av电影一区| 免费av网址在线| 视频精品一区二区| 日韩av手机版| 精品亚洲成a人| www.日本久久| 粉嫩一区二区三区在线看| 无码国产精品一区二区免费式直播| 国产精品99久久久久久久女警| 日本黄色www| 国产高清视频一区| 性活交片大全免费看| av电影一区二区| 中文字幕免费看| 国产天堂亚洲国产碰碰| 国产成人精品视频免费| 亚洲理论在线观看| 日本熟妇毛茸茸丰满| 色婷婷av久久久久久久| 在线观看免费视频一区| 91精品国产麻豆国产自产在线 | 成人va在线观看| 久久丫精品国产亚洲av不卡| 国产欧美一二三区| 亚洲不卡在线播放| 亚洲v日本v欧美v久久精品| 国产情侣自拍av| 欧美日韩免费观看一区二区三区| 国产内射老熟女aaaa∵| 欧美精品一区二区在线播放 | 日韩丝袜视频| 亚洲激情一区二区| 国内一区二区三区| 国产a视频免费观看| 久久99精品久久久久| 亚洲美女高潮久久久| 久久一区二区视频| 一级性生活免费视频| 亚洲成av人片一区二区三区| 波多野结衣一区二区在线| 日韩一区二区三区免费看| 偷拍自拍在线| 欧美精品性视频| 精品国产免费人成网站| 亚洲a区在线视频| 中文字幕中文字幕精品| 四虎免费在线观看视频| 性欧美精品高清| 亚洲AV无码久久精品国产一区| 26uuu久久综合| 丝袜 亚洲 另类 欧美 重口| 一本大道久久精品懂色aⅴ| 国产精品久久久久久69| 精品爽片免费看久久| 最新av在线播放| 国产成人91久久精品| 粉嫩av一区二区| 手机在线视频你懂的| 久久一区中文字幕| 美国黄色一级视频| |精品福利一区二区三区| 9i看片成人免费看片| 日韩视频一区二区三区| av成人手机在线| 日本精品视频在线播放| av成人男女| 在线精品日韩| 久久人人超碰| 亚洲国产欧美视频| 亚洲一区在线视频观看| 亚洲视频一区在线播放| 一区二区三区日韩在线| 人成在线免费网站| 懂色一区二区三区av片| 亚洲精品97| 中文字幕22页| 国产精品色哟哟| 无码人妻久久一区二区三区 | 国产精品一区在线观看| 伊人久久大香线蕉综合四虎小说 | 无码人妻av一区二区三区波多野 | 色帝国亚洲欧美在线| 成人黄色av网站| 99久久影视| 色婷婷.com| 中文字幕一区二区三| 最近国语视频在线观看免费播放| 亚洲欧美精品中文字幕在线| 亚洲天堂电影| 精品久久久久久中文字幕动漫 | 黄页网站在线看| 亚洲欧洲另类国产综合| 97超碰国产在线| 久久久成人av| 免费观看在线一区二区三区| 日日噜噜噜夜夜爽爽| 精品一区二区在线观看| 69xxx免费| 欧美日韩在线免费视频| 成人动漫在线播放| 国产精选久久久久久| 成人在线丰满少妇av| www.久久久精品| 综合网在线视频| 97caocao| 欧美激情精品久久久久久大尺度 | 成人av在线看| 国产精品第72页| 日韩精品视频在线播放| 成人国产二区| 亚洲v欧美v另类v综合v日韩v| 蜜臀a∨国产成人精品| 在线观看黄网址| 日韩欧美国产三级电影视频| 91桃色在线观看| 蜜桃视频日韩| 男男视频亚洲欧美| 国产精品免费人成网站酒店 | 四季av综合网站| 日韩欧美aⅴ综合网站发布| 黄色av网站在线看| 国产区亚洲区欧美区| 欧美激情麻豆| 亚洲天堂网一区二区| 在线免费观看日本欧美| 蜜桃视频在线观看www社区| 国产66精品久久久久999小说| 今天的高清视频免费播放成人| 欧美做受喷浆在线观看| 欧美在线观看视频一区二区| 黄色网页网址在线免费| 国产精品久久久一区二区三区| 先锋影音久久久| 紧身裙女教师波多野结衣| 亚洲国产成人久久| 97精品国产99久久久久久免费| 91麻豆天美传媒在线| 97久久超碰国产精品| 91在线视频国产| 97碰在线观看| 欧美gvvideo网站| 玖玖爱在线精品视频| 欧美日韩精品免费观看视频| a√中文在线观看| 手机成人av在线| 久久网这里都是精品| 国产免费久久久| 国产成人+综合亚洲+天堂| 国产精品成人一区二区网站软件| 免费看污片网站| 亚洲国产精品久久| 亚洲精品一区av|