ZooKeeper way to explore https:https://cdn.v2ex.com/navatar/2afe/4567/719_normal.png?m=1377460266 https:https://cdn.v2ex.com/navatar/2afe/4567/719_large.png?m=1377460266 2021-02-24T11:57:09Z Copyright © 2010-2018, V2EX Zookeeper Go Client 原理总结 tag:www.v2ex.com,2021-02-24:/t/755955 2021-02-24T11:55:12Z 2021-02-24T11:57:09Z codeboy18 member/codeboy18

更多精彩内容,请关注微信公众号:后端技术小屋

〇、环境

zk client: github.com/samuel/go-zookeeper

一、zk client 状态

zookeeper 是一款流行的分布式协调组件,被广泛用于 leader 选举、分布式锁、服务发现、名称服务、配置中心等场景。

1. 状态含义

zk client 与 zk server 在建立连接、保持连接、断开连接的过程中,会经历各种状态。如下所示

const ( // 暂未使用     StateUnknown           State = -1 // 与 zk server 之间的连接断开(也包含初始状态),此时 zk client 会不断重连     StateDisconnected      State = 0 // 与 zk server 建立连接之前的暂时状态,表示即将 connect zk server     StateConnecting        State = 1 // 暂未使用     StateAuthFailed        State = 4 // 暂未使用     StateConnectedReadOnly State = 5 // 暂未使用     StateSaslAuthenticated State = 6 // 在和 zk server 重新建立 TCP 连接之后,握手阶段发现 session 超时     StateExpired           State = -112 // 在和 zk server 成功建立 TCP 连接之后的状态     StateConnected  = State(100) // 和 zk server 成功建立 TCP 连接,并且成功握手(即成功创建 session) StateHasSession = State(101) ) 

2. 状态转换

二、超时时间

超时时间很大程度上影响了上述状态的转换,有三个超时时间值得关注:

func (c *Conn) setTimeouts(sessionTimeoutMs int32) {     c.sessionTimeoutMs = sessionTimeoutMs     sessionTimeout := time.Duration(sessionTimeoutMs) * time.Millisecond     c.recvTimeout = sessionTimeout * 2 / 3     c.pingInterval = c.recvTimeout / 2 } 

三、异常处理

// Connect establishes a new connection to a pool of zookeeper // servers. The provided session timeout sets the amount of time for which // a session is considered valid after losing connection to a server. Within // the session timeout it's possible to reestablish a connection to a different // server and keep the same session. This is means any ephemeral nodes and // watches are maintained 

如果 client 和 server 端连接发生异常,可分为三种情况:

推荐阅读

更多精彩内容,请扫码关注微信公众号:后端技术小屋。如果觉得文章对你有帮助的话,请多多分享、转发、在看。
二维码

]]> 不懂就问: Zookeeper 分布式锁实现过程中如何保证原子性? tag:www.v2ex.com,2021-02-02:/t/750504 2021-02-02T01:49:16Z 2021-04-03T00:24:56Z garyxiongxiong member/garyxiongxiong 在实现 zookeeper 分布式锁的过程中,为了避免羊群效应,需要在阻塞获取锁的过程中执行以下步骤:

  1. 添加顺序临时节点至锁路径
  2. 获取所路径下的节点列表,判断添加的节点是否在第一位,不在则需阻塞等待锁
  3. 获取节点列表,并监听当前的前一节点
  4. 等待前一节点被删除,重新检查是否获取到锁

在按此逻辑编写后,发现第三步中存在问题,可能会出现如下情况:

在获取节点列表并计算出前一节点preNode后,监听preNode删除事件前,此preNode被删除,则监听器永远不会被触发,造成死锁。

这种情况如何保证第三步的原子性?

]]>
etcd vs zookeeper tag:www.v2ex.com,2020-03-31:/t/658022 2020-03-31T09:43:39Z 2020-04-05T16:56:42Z ruandao member/ruandao 什么情况下,选择 etcd

什么情况下,选择 zookeeper

为什么

网上很多博客列了一堆优缺点,但是。。。大脑里面无法形成判断,“想要什么的时候,由于有什么优点缺点,所以选择 xxx”

]]>
zookeeper 关于事务提交的一点疑惑 tag:www.v2ex.com,2018-12-07:/t/515293 2018-12-07T03:28:56Z 2019-05-14T12:10:10Z Miiiz member/Miiiz 当一个事务请求得到过半 follower 的 ACK 响应时,leader 会下发 commit 消息给 learner,leader 自身也会 commit,然后其实就是各个角色进入 CommitProcessor-》 FinalRequestProcessor,然后去执行事务刷新到内存,这个操作的话,肯定会存在部分失败,部分失败,那 leader 失败或者 learner 失败了,就会出现数据不一致的情况,这该怎么办?希望有大佬给点提示,感激不尽

]]>
ubao msn snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86