本文介绍: 一般是客户端执行getData(“/节点A”,true),如果节点A发生了变更删除客户端会得到它的watch事件,但是在之后节点A又发生了变更,而客户端没有设置watch事件,就不再给客户端发送官方声明一个Watch事件一个一次性的触发器,当被设置了Watch数据发生了改变的时候,则服务器这个改变发送给设置了Watch客户端以便通知它们。为什么不是永久的,举个例子,如果服务端变动频繁,而监听客户端很多情况下,每次变动都要通知所有客户端,这太消耗性能了。这是比较常用方式

1、Zookeeper什么框架

分布式的、开源分布式应用程序协调服务,原本是Hadoop、HBase一个重要组件

应用场景

Zookeeper功能很强大,应用场景很多结合我实际工作使用Dubbo框架的情况,Zookeeper主要是做注册中心用。

基于Dubbo框架开发的提供者、消费者都向Zookeeper注册自己的URL,消费者还能拿到并订阅提供者的注册URL,以便在后续程序执行中去调用提供者。而提供者发生了变动,也会通过Zookeeper订阅消费发送通知。

2、Zookeeper有哪几种节点类型

持久创建之后一直存在,除非有删除操作创建节点客户会话失效也不影响节点

持久顺序:跟持久一样,就是节点创建下一级子节点时候记录每个子节点创建的先后顺序,会给每个子节点名加上一个数后缀

临时创建客户会话失效注意是会话失效,不是连接断了),节点也就没了。不能建子节点。

临时顺序不用解释了吧。

3、Zookeeper对节点的watch监听通知是永久的吗?

不是。官方声明一个Watch事件一个一次性的触发器,当被设置了Watch数据发生了改变的时候,则服务器这个改变发送给设置了Watch客户端,以便通知它们。

为什么不是永久的,举个例子,如果服务端变动频繁,而监听的客户很多情况下,每次变动都要通知到所有客户端,这太消耗性能了。

一般是客户执行getData(“/节点A”,true),如果节点A发生了变更或删除,客户端会得到它的watch事件,但是在之后节点A又发生了变更,而客户端又没有设置watch事件,就不再给客户发送

在实际应用中,很多情况下,我们的客户端不需要知道服务端的每一次变动,我只要最新的数据即可

部署方式集群中的机器角色都有哪些集群最少要几台机器

单机,集群。Leader、Follower。集群最低3(2N+1)台,保证奇数,主要是为了选举算法

4、Zookeeper集群如果有3台机器,挂掉一台集群还能工作吗?挂掉两台呢?

记住一个原则:过半存活即可用。

集群支持动态添加机器吗?

其实就是水平扩容了,Zookeeper在这方面不太好。两种方式

全部重启关闭所有Zookeeper服务修改配置之后启动。不影响之前客户端的会话。

逐个重启:顾名思义。这是比较常用方式
 

原文地址:https://blog.csdn.net/2302_77913771/article/details/134811868

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任

如若转载,请注明出处:http://www.7code.cn/show_48844.html

如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱suwngjj01@126.com进行投诉反馈,一经查实,立即删除!

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注