行杂记之Zookeeper SessionTimeOut分析
来源:互联网 发布:oracle数据库字段类型 编辑:程序博客网 时间:2024/06/08 04:56
摘要: 近期的一个C++项目里使用了Zookeeper做服务发现,期间遇到了SessionTimeOut问题的困扰,明明通过zookeeper c client设置了超时时间,但无效。 请原谅我一开始对zookeeper不熟悉。
0.前言
本文为笃行日常工作记录,烂笔头系列。
源码前面,了无秘密 — by 侯杰
近期的一个C++项目里使用了Zookeeper做服务发现,期间遇到了SessionTimeOut问题的困扰,明明通过zookeeper c client设置了超时时间,但无效。
请原谅我一开始对zookeeper不熟悉。最终通过分析源码了解到SessionTimeOut最终的确定是一个协商的过程,而不是简单的配置生效。
在这里记录下Session超时时间的有关分析,基于zookeeper 3.4.8
1.zookeeper client SessionTimeOut
项目中使用的是 C client,通过zookeer_init
创建zk session,调用了zookeeper_init其实就开始了建立链接到ZK集群的过程,这里设置的recv_timeout 为客户端所期望的session超时时间,单位为毫秒。
连接成功之后客户端发起握手协议,可以看到之前设置的recv_timeout随握手协议一起发送给服务端,zookeeper.c#L1485。
再来看看处理握手协议Resp的逻辑 zookeeper.c L1767
至此可以发现,最终客户端的SessionTimeOut时间实际是经过服务端下发之后的,并不一定是最先设置的。
2.Zookeeper Server SessionTimeOut
2.1协商客户端上报的SessionTimeOut
来看看服务端握手的处理逻辑ZooKeeperServer.java#L876。
可以一句话概括,客户端上报的期望timeout一定要在服务端设置的上下界之间,如果越过边界,则以边界为准。
2.2 服务端MinSessionTimeOut和MaxSessionTimeOut的确定
原文链接
- 行杂记之Zookeeper SessionTimeOut分析
- 杂记之算法分析
- uboot杂记之时钟分析
- zookeeper 存储之文件格式分析
- zookeeper存储之实现分析
- zookeeper 存储之文件格式分析
- zookeeper 存储之文件格式分析
- springboot 设置sessiontimeout
- zookeeper全分析之我见一
- Zookeeper源代码阅读分析之watcher机制
- zookeeper源码分析之leader选举
- Zookeeper源码分析之二Session建立
- 【Zookeeper】源码分析之持久化--FileTxnSnapLog
- 【Zookeeper】源码分析之持久化--FileSnap
- Zookeeper源码分析之请求处理链
- Zookeeper源码分析之持久化(一)
- Zookeeper源码分析之持久化(二)
- Zookeeper源码分析之持久化(三)
- 400
- Centos7防火墙firewall简单介绍
- linux中mysql用到my.cnf
- Pinyin4j的基本用法
- STL中clear()操作方法的使用细节
- 行杂记之Zookeeper SessionTimeOut分析
- java访问者模式
- 【剑指offer】题47:不用加减乘除做加法
- sql笔记本
- 17Jquer定时刷新以及循环遍历功能和ajax 的异步请求数据
- JPA中的Page与Pageable
- Git错误non-fast-forward后的冲突解决
- Java list add方法和addAll方法效率
- Android 引用Toolbar/ActionBar视图左边有空白