zookeeper怎么保证一致性
答案:2 悬赏:50
解决时间 2021-03-05 14:07
- 提问者网友:呆萌心雨
- 2021-03-05 04:12
zookeeper怎么保证一致性
最佳答案
- 二级知识专家网友:短发女王川岛琦
- 2021-03-05 04:46
zookeeper中的persit机制主要是通过本地disk进行持久化,在本地disk上会有个memory数据对象保持同步。 持久化实现: ZKDatabase DataTree (内存树) FileTxnSnapLog (disk持久化) committedLog (FileTxnSnapLog的一份内存数据cache,默认存储500条变更记录) DataTree(内存树) zookeeper本身的数据结构就是一个树结构 数据模型(DataTree): DataNode (1:n) data WatchManager (1:1,处理node节点的CRUD的变更事件,发送Watcher事件) child WatchManager (1:1, 处理node子节点的变更事件,发送Watcher事件) sessions (ephemerals) DataNode模型: parent data byte[] acl(安全) stat(审计信息) children 整个实现相对比较简单,就是查找一个树节点后进行响应的操作 FileTxnSnapLog (disk持久化) 持久化数据分两类: TxnLog (类似于mysql/oracle的binlog/redolog) SnapShot (DataTree的数据镜像) 刚开始最容易搞不清楚就是Txnlog和SnapShot的区别,SnapShot主要是定期对DataTree的数据做一个本地备份,TxnLog只是一些历史的版本变更日志(每次由写事件变化,就会写入到该日志中)。
全部回答
- 1楼网友:无字情书
- 2021-03-05 06:02
同问。。。
我要举报
如以上问答内容为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
大家都在看
推荐资讯