Zookeeper原理和组件

简介:本文主要描述了zookeeper的工作原理和两大组件:zkdatabase和watch机制,适合作为原理理解。

Zookeeper的工作原理

        Zookeeper(以下简称ZK)是一个分布式环境下的事务的协调者,为其他分布式环境下的软件系统提供协调服务。它的主要工作为当分布式环境下系统出现数据不一致,用它来做最终的协调,也就是它来告诉分布式系统,你这个数据应该是什么。通俗的来讲,拿疫情来举例,当某个地区发生疫情时,各种小道消息满天飞,各个公司都不知道明天能否正常上班,到底是居家办公还是可以到公司办公。那么ZK就是来告诉你,明天是能上班还是不能上班。

        ZK是一个集群,集群中的每个节点,有三个角色,leader、follower和observer ,对应的介绍为:

        leader:集群的领导者,负责数据写入、发送数据确认和接收、新加入节点的数据同步、为客户端提供数据读服务。有选举权和被选举权

        follower:集群的节点,负责为客户端提供数据读服务,负责转发客户端的写请求给leader,有选举权和被选举权。

        observer:集权的观察者,负责为客户端提供数据读服务,负责转发客户端的写请求给leader,没有选举权和被选举权,主要使用场景是当zk集群压力过大时,使用observer节点来分摊压力。

        ZK实现的原理是什么呢,最基本的原理,也就是为其他系统服务的内核,是半数以上通过原则。这个原则体现在三个方面:

        1、选举确认

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值