chubby总结

目录

架构

文件名空间

分布式锁

缓存一致性

chubby master故障恢复

client和chubby master交互

master故障恢复

master选举流程

chubby服务端架构

paxos算法实现


chubby是一个面向松耦合分布式系统的锁服务,是paxos算法的工程实现。

架构

如图,chubby锁服务有中心化节点,这里以5个实例组成的chubby集群为例,根据paxos算法选举唯一master,client通过lib向chubby master发送rpc请求和接收响应。master和其他chubby实例间通过paxos算法同步修改操作。

文件名空间

chubby的文件接口和unix文件系统类似,具体实现是文件和目录组成的树形空间,因此没有unix文件系统中的软、硬链接等概念。

分布式锁

分布式系统环境由于网络通信的不确定性,锁的获取释放会出现乱序、重复等问题,例如,一个client A在锁的保护下发出了请求R1,因为网络原因导致这个请求一直没有到达chubby master,应用程序任务这个client已经失效,于是为client B分配了同一把锁,发出了请求R2并生效,随后R1到达,造成数据不一致。chubby采用两个策略解决分布式锁问题:

  • 锁延迟:若一个锁因为异常情况被释放,如client失联,chubby master会将这个锁保留一段时间,这样可以解决网络短暂故障导致的client闪断问题,这类case占比重很大
  • 锁序列化:为每个锁的持有者分配一个序列号,每次获取锁序列号自增,序列号随请求携带,chubby master收到请求后校验序列号,从而发现过期的请求并拒绝

缓存一致性

clien

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值