Vector Clock 简介

引言:

最近重读http://book.mixu.net/distsys/ebook.html,在分布式文件系统,如何掌握写入内容的先后关系是重要的一环,因为在并发写入的过程中,可能会导致多个版本同时出现的情况,但是使用物理时钟显然是不靠谱的,所以我们采用一种逻辑时钟来为对象构建一种偏序的(partial ordering)的时序集合,同时这个也是Amazon在他们的Dynamo中的实践原理。

简介:

VectorClock是一种用向量来表示偏序关系的逻辑时钟,从数据结构上可以理解为一个集合内包含所有节点的“时间戳”,当然这个时间戳并不是物理意义上的时间(也有些实践会同时加入timestamps以解决冲突问题),而是由程序赋予的逻辑计数(count),{Node1:0,Node2:2,Node3:3…….},如果我们已经统一了向量内的位置对应的node,那么时钟可以直接用一个{0,2,3}来表示。

对于每一个分布式存储的对象副本都有这样一个时间戳,那么存在一下几种关系:

a: 本机:{0,0,1} 消息:{0,1,2}。消息的每个节点的count都大于等于本机的,那么舍弃本机,同步消息
b: 本机:{0,1,2} 消息:{0,1,1}。消息的每个

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值