etcd踩坑记录

etcd踩坑记录

问题:获取etcd锁时一直阻塞

这里写图片描述

运行结果:

这里写图片描述

原因:

​ 出现这种问题的原因和etcd的分布式锁的实现原理有关,简单来说:etcd的锁实现原理就是

所有的客户端都在pfx(这里就是/pfx/v1)下创建一个自己的key,createrevision最小的那个客户端获得锁,也就是最早建立key的客户端获得锁,之后按照创建的时间先后依次获得锁。

​ 由于我们最开始在pfx下建立的一个key,所以它的创建时间回比我们创建的所有关于锁的key的创建时间要早,导致我们永远获取不到锁。

​ 详细信息可以参考 cadem 这位博主的一篇文章 用Etcd实现分布式锁和选主

解决办法:

​ 谨慎选择锁的pfx的值,确定除了锁之外不会在此之下创建或修改其他key

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值