`
tcspecial
  • 浏览: 911639 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

zookeeper Session Expired

    博客分类:
  • java
阅读更多

zookeeper 客户端封装比较优雅,当服务器中断或网络超时时,会自动重连服务器。

但是当某些其它未知原因出现,例如网络超时导致的客户端报错:Session Expired,导致重连失败。

 

zookeeper客户端与服务器维持一个长连接,每个连接拥有唯一的session id。Session连接通常是一直有效,如果因为网络原因断开了连接,客户端会使用相同的session id进行重连。

 

解决方案:当session失败时,只需新建一个客户端连接,不依赖之前的session id。

/**
 * zookeeper 事件回调函数
 *
 */
void watcher( zhandle_t *zh,int type,int state,const char *path,void *ctx )
{	
	// session失效
	if( type == ZOO_SESSION_EVENT 
		&& state == ZOO_EXPIRED_SESSION_STATE )
	{
		zookeeper_close( zh );
			
		// 重连
		zkh = zookeeper_init( "xxx:2181",watcher,10000,0,0,0 );
		if( zkh == NULL )
		{
			printf( "Fail to connect zookeeper" );
			return;
		}
	}
}

 

 

 

分享到:
评论

相关推荐

    zookeeper分布session式实现

    ### 基于ZooKeeper的分布式Session实现详解 #### 1. 认识ZooKeeper ZooKeeper,形象地被称为“动物园管理员”,在分布式系统中扮演着至关重要的角色。随着企业级应用系统的不断扩展,传统的单体架构难以应对日益...

    zookeeper实现分布式session sample

    Zookeeper,作为Apache的一个开源项目,是一个高可用、高性能的分布式协调服务,它为解决分布式环境下的session共享提供了有效的解决方案。本示例将探讨如何利用Zookeeper实现分布式session。 1. **Zookeeper的基本...

    基于ZooKeeper的分布式Session实现

    本文将深入探讨如何利用ZooKeeper实现分布式Session,并通过分析提供的"基于ZooKeeper的分布式Session实现.doc"文档,解析其实现原理与步骤。 首先,理解ZooKeeper的基本概念至关重要。ZooKeeper是一个高可用、高...

    zookeeper-session:使用 zookeeper 管理会话而不是 memcached

    在分布式系统中,管理和协调服务的状态是至关重要的,这就是 Apache ZooKeeper 的作用所在。ZooKeeper 是一个分布式的,开放源码的分布式应用程序协调服务,它为分布式计算提供了一个高可用、高性能的解决方案。本...

    zookeeper-3.4.6_zookeeper_

    《Zookeeper:分布式服务治理的核心组件》 Zookeeper,作为Apache的一个开源项目,是分布式应用程序协调服务的基石,它是一个高可用、高性能的分布式一致性服务。在标题“zookeeper-3.4.6_zookeeper_”中,我们可以...

    基于ZooKeeper的分布式Session实现_已发布.docx

    【基于ZooKeeper的分布式Session实现】 ZooKeeper是一个分布式协调服务,源于Apache Hadoop项目,现已成为一个独立的子项目。它旨在提供高可用性、高性能的协调服务,适用于分布式环境中的命名、配置管理、同步和组...

    zookeeper集群

    ZooKeeper集群搭建和管理 ZooKeeper是一种广泛使用的分布式协调服务,常用于分布式系统中的服务注册、配置管理、群策略管理等方面。下面将从 ZooKeeper 集群的搭建、配置、管理等方面进行详细的知识点介绍。 一、...

    zookeeper-3.8.0安装包下载

    Zookeeper 的核心概念包括节点(Znode)、会话(Session)和观察者(Watcher)。Znode 是 Zookeeper 数据存储的基本单位,类似于文件系统中的节点,分为临时节点和永久节点两种。会话是客户端与 Zookeeper 服务器...

    ZooKeeper-分布式过程协同技术详解 和从Paxos到Zookeeper

    首先,ZooKeeper的核心概念包括节点(Znode)、会话(Session)和Watcher。Znode是数据存储的基本单元,它们类似于文件系统的文件和目录,有生命周期管理,并支持版本控制和ACL(访问控制列表)。会话是客户端与...

    zookeeper 3.6.3 源码下载

    2. **会话(Session)**:客户端与ZooKeeper服务器建立的连接称为会话,会话期间,客户端可以发送请求并接收响应,会话具有超时机制。 3. **Watcher**:ZooKeeper提供了一种事件监听机制,称为Watcher,允许客户端...

    【Zookeeper管理工具】

    3. **会话(Session)**: 用户与Zookeeper服务器之间的连接称为会话,会话期间,Zookeeper服务器会保持与客户端的连接状态,如果会话超时或网络中断,会话结束。 **Zookeeper管理工具的功能** 1. **集群监控**: ...

    zookeeper可视化工具

    **Zookeeper可视化工具详解** Apache ZooKeeper 是一个分布式协调服务,它为分布式应用程序提供高度可靠的命名服务、配置管理、集群同步、领导选举等核心功能。在运维和开发过程中,为了更方便地管理和监控...

    Zookeeper_安装和配置

    Zookeeper 是一个分布式的,开放源码的分布式应用程序协调服务,它是集群的管理者,监视着集群中各个节点的状态根据节点提交的反馈进行下一步合理操作。最终将简单易用的接口和性能高效、功能稳定的系统提供给用户。...

    centos8安装zookeeper3.8.0详细步骤

    CentOS 8 安装 ZooKeeper 3.8.0 详细步骤 ZooKeeper 是一个分布式应用程序协调服务,提供了配置管理、名称服务、分布式同步和提供组服务等功能。下面是 CentOS 8 安装 ZooKeeper 3.8.0 的详细步骤。 1. 下载安装包...

    zookeeper增加权限登录验证

    ZooKeeper 增加权限登录验证 ZooKeeper 是一个广泛使用的分布式协调服务,它提供了许多有用的功能,如配置管理、名字服务、分布式锁等。然而,在 ZooKeeper 中存在一些安全漏洞,例如未经授权的访问、数据泄露等。...

    zookeeper linux集群搭建流程

    zookeeper Linux 集群搭建流程 ZooKeeper 是一个广泛使用的分布式协调服务,主要用于管理和协调分布式系统中的各个节点。Linux 集群搭建是 ZooKeeper 的一种常见应用场景,本文将详细介绍 ZooKeeper Linux 集群搭建...

    zookeeper 3.8.4

    - **会话(Session)**:客户端与 ZooKeeper 服务器之间的连接称为会话。会话期间,服务器会监控客户端的活动,并在会话超时或客户端断开连接时执行相应的操作。 - **Watcher 事件监听**:Zookeeper 支持 Watcher ...

    zookeeper版本为zookeeper-3.4.10.tar.gz

    2. **会话(Session)**:客户端与Zookeeper服务器建立的连接称为会话,会话期间,服务器会持续监控客户端的状态,如果客户端因为网络故障断开连接,Zookeeper会根据预设的超时时间决定是否关闭该会话。 3. **...

Global site tag (gtag.js) - Google Analytics