java面试题网

普通会员

15

帖子

1

回复

33

积分

楼主
发表于 2018-06-06 17:31:29 | 查看: 361| 回复: 0

Zookeeper是什么框架


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


应用场景


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


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


Zookeeper有哪几种节点类型


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


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


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


临时顺序:不用解释了吧。


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


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


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


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


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


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


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


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


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


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


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


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


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



您需要登录后才可以回帖 登录 | 立即注册

java面试题网无聊看看网与java建站系统提供技术支持V2.1 网站地图 © 2016-2018