`

zookeeper简述

 
阅读更多

zookeeper是一个分布式协调服务框架,主要用来解决分布式集群中应用系统的一致性问题,例如如何避免同时操作同一数据造成脏读的问题。本质上是一个分布式小文件存储系统,提供基于类似于文件系统的目录树方式的数据存储,并且可以对树中的节点进行有效管理,从而用来维护和监控被存储的数据的状态变化。通过监控这些数据的状态变化,从而达到基于数据的集群管理。如统一命名服务、分布式配置管理、分布式消息队列、分布式所、分布式协调等功能。

 

zookeeper集群角色

 

leader:zookeeper集群工作的核心,主要责任如下:事务请求(写操作)的唯一调度及处理者,保证集群事务处理的顺序性;集群内部各个服务器的调度者。对于create,setData,delete等有写操作的请求,则需要统一转发给leader处理,leader需要决定编号、执行操作,这个过程称为一个事务。

follower:处理客户端非事务(读操作)请求,转发事务请求给leader,参与集群leader选举投票。

observer:充当观察者角色,观察zookeeper集群的最新状态变化并将这些状态同步过来,其对于非事务请求可以单独进行处理,对于事务请求,则会转发给leader服务器进行处理。不会参与任何形式的投票只提供非事务服务,通常用于在不影响集群事务处理能力的前提下提升集群的非事务处理能力。

 

特性

全局数据一致:每个server保存一份相同的数据副本,client无论连接到那个server,展示的数据都是一致的,这是最重要的特征

可靠性:如果消息被其中一台服务器接受,那么将被所有的服务器接受。

顺序性:包括全局有序和偏序两种,全局有序是指如果在一台服务器上消息X在Y前发布,则所有server上消息X都将在Y前被发布,偏序是指一个消息Y在消息X后被同一个发布者发布,X

必将排在Y前面

数据更新原子性,一次数据更新要么成功(半数以上节点成功),要么失败,不存在中间状态

实时性:zookeeper保证客户端将在一个时间间隔范围内获得服务器的更新信息,或者服务器失效信息。

 

分享到:
评论

相关推荐

    dubbo和zookeeper的关系简述

    dubbo和zookeeper的关系、 Dubbo和ZooKeeper是两个在分布式系统中经常一起使用的开源软件。 Dubbo是一个高性能的Java RPC框架,用于构建分布式应用和服务。它提供了服务治理、负载均衡、容错机制等功能,使得开发者...

    hornsey#ARTS#W3-zookeeper应用场景简述1

    配置维护大型分布式场景中,对相同配置的集群服务器集中进行配置管理,各服务器在zookeeper中注册watcher监听,发布者更新配置后,zookeeper向订

    ZooKeeper原理及其在Hadoop和HBase中的应用.docx

    ZooKeeper是一个广泛使用的开源分布式协调服务,由雅虎开发,其设计灵感来源于Google的Chubby系统。它的主要目标是为分布式应用程序提供一致性服务,包括数据发布/订阅、负载均衡、命名服务、分布式协调/通知、集群...

    第6章 Zookeeper 2 6.1. Zookeeper入门 2 6.1.1. 概述 2 6.1.2. 特点 3 6.1.3

    第6章 Zookeeper 2 6.1. Zookeeper入门 2 6.1.1. 概述 2 6.1.2. 特点 3 ...6.5.1. 请简述ZooKeeper的选举机制 37 6.5.2. ZooKeeper的监听原理是什么 37 6.5.3. ZooKeeper的部署方式有哪几种?集群中的角

    Mycat-cluster组件设计方案简述.docx

    配置方面,用户需要设置`mycat.cluster=on`以启用集群模式,`mycat.cluster.zookeeper.connectString`用于指定Zookeeper集群的连接地址,`mycat.cluster.zookeeper.sessionTimeout`定义了Zookeeper会话超时时间,而`...

    面试简述.docx

    【面试简述】 在面试中,李俊才作为一名大三的计算机科学与技术专业的学生,展示了他在实际项目中的技能和经验。他参与开发了一个基于SpringBoot+MyBatis的购物商城项目,具备登录、订单和商品管理等功能。项目采用...

    Mycat-cluster设计简析

    下面是 Mycat-cluster 的组件设计方案简述: 一、集群中 Mycat 节点服务状态跟踪 Mycat-cluster 可以方便地查看集群中各个节点的 server 状态,以及所有节点之间的网络关系。当节点状态异常时,可以获得通知消息等...

    大数据重点面试题(网盘链接,全面)

    请简述Zookeeper的Leader选举算法。** Zookeeper使用一种称为ZAB(Zookeeper Atomic Broadcast)的协议来进行Leader选举。当集群中的某个节点想要成为Leader时,它会向其他节点发送一个包含自己ID的消息,其他节点...

    PyPI 官网下载 | dawgie-1.3.0rc20.tar.gz

    2. **文档**:可能有README文件,简述项目用途和快速入门指南。 3. **测试**:测试用例(test_*.py)确保库的功能正常运行。 4. **配置**:如配置样例或默认设置文件。 5. **安装脚本**:setup.py文件,用于使用pip...

    大数据精品项目-基于ssm+spark的电影推荐系统.zip

    ssm+spark+jdk1.8+mysql5.7 ...hadoop技术: hadoop + hive + kafka + flume + spark + scala + zookeeper + nginx + python等 3、注意 该项目涉及的技术比较多,需要一定javaweb和大数据功力的技术

    java项目-第42期基于ssm项目源码小区管理物业系统.zip

    1、项目简述 该校区管理系统是以服务客户为核心,以提高处理效率和节省劳动成本为目标,实现了资源管理 、收费管理、支出管理、三表管理、投诉建议、装修管理、车位管理、招商管理、 物料管理、设备管理、人事考勤、...

    深入理解HBase的系统架构

    这三种服务器分别是:Regionserver,HBaseHMaster,ZooKeeper。其中Regionserver负责数据的读写服务。用户通过沟通Regionserver来实现对数据的访问。HBaseHMaster负责Region的分配及数据库的创建和删除等操作。...

    java大数据作业_3HBase

    简述HBase的表操作对象 HBase提供了多种API来操作表,包括: - `Admin`: 用于管理表,如创建、删除表等。 - `Table`: 用于执行对表的具体操作,如插入、查询数据等。 - `HTableDescriptor`: 描述表的元数据,如列...

    1000道 互联网Java工程师面试题 485页

    #### 27、简述Mybatis的插件运行原理,以及如何编写一个插件。 - **运行原理**:MyBatis插件是基于AOP思想实现的,通过对执行过程中的关键点进行拦截,实现对SQL执行过程的增强。 - **编写插件**:实现`Intercepter...

    1000道 互联网Java工程师面试题 485页_PDF密码解除.pdf

    简述Mybatis的插件运行原理,以及如何编写一个插件。** - **运行原理:**MyBatis通过拦截器(Interceptor)机制实现插件功能,插件可以拦截SQL执行过程中的各个阶段。 - **编写插件:**实现`Interceptor`接口,并...

    ssm Dubbo分布式系统架构实战入门,良心详解之作二

    1. **SSM 框架简述** - Spring:作为核心容器,负责管理应用对象的生命周期和依赖注入。 - SpringMVC:处理HTTP请求,提供Model-View-Controller模式实现,简化Web应用开发。 - MyBatis:轻量级持久层框架,将SQL...

    分布式文件系统HDFS原理与操作

    它并不是NameNode的热备份,一旦NameNode发生故障,SecondaryNameNode并不能直接替代NameNode,而是需要结合其他机制比如ZooKeeper来实现NameNode的高可用。 以上就是HDFS的原理与操作相关的知识点,从其设计思想到...

    Java-web环境所需软件

    9. **容器和服务发现**: 在分布式环境中,如Docker容器化和Kubernetes集群中,服务发现机制如Consul、Zookeeper或Eureka可以帮助定位和管理运行中的服务。 10. **安全配置**: Java-web应用的安全性是关键,需要关注...

    分布式系统概述

    4. **分布式协调服务**:如Zookeeper和Etcd,用于管理配置信息、命名服务、分布式锁、集群成员关系等,确保分布式系统中的节点能够高效、正确地协作。 5. **负载均衡**:通过将请求分散到不同的节点,减少单个节点...

Global site tag (gtag.js) - Google Analytics