码迷,mamicode.com
首页 > 其他好文 > 详细

zookeeper应用场景

时间:2015-02-28 14:40:25      阅读:155      评论:0      收藏:0      [点我收藏+]

标签:zookeeper

zookeeper采用了fast paxos算法,该算法比paxosa算法好的地方是解决了几个proposer交替发出提案,导致没有一个提案被批准的活锁问题。

为什么需要zookeeper?我想有以下几个应用场景:

1. 配置管理

如果我们有很多服务程序需要有一些配置信息,可以保存在zookeeper的对应的znode中。zookeeper保证多个服务器同时对znode里面信息的修改是一致的。

当然也可以用其他的方式来实现,比如NoSQL或者RDBMS集群。有以下几个区别:

a. zookeeper提供了事件机制,当配置被修改后,这些服务程序可以收到通知。这里使用的是Zookeeper的Watcher机制。

b. 另外,如果仅作配置管理,用NoSQL或者RDBMS集群的确有点奢侈,还是zookeeper性价比好。

c. 至于配置文件的方式,不适合分布式管理,就更不好了。



2. 故障通知

你的程序可能依赖某个服务,用EPHERMAL结合Watcher机制,可以监控依赖的服务程序是否活着,从而作出相应的操作。


3. 选举master

很多分布式服务都需要这个功能,包括zookeeper自己。MongoDB自己实现了选举策略,但是如果要让自己编写的程序具备这个功能,可以考虑不开发,学会使用zookeeper帮你做到这点,让自己的程序成为zookeeper的客户端。



这篇博客描述的较细,可进一步参考。



zookeeper应用场景

标签:zookeeper

原文地址:http://blog.csdn.net/csfreebird/article/details/43984425

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!