分享

使用Zookeeper与Thrift构建Ha的LogServer


问题导读
1.你对zookeeper了解多少?
2.Curator主要解决了哪三类问题?
3.Curator的作用是什么?






zookeeper简介
     ZooKeeper是一个分布式的,开放源码的分布式应用程序协调服务,它包含一个简单的原语集,分布式应用程序可以基于它实现同步服务,配置维护和命名服务等。目前zookeeper被应用于hadoop/hbase中进行节点的管理,通过zookeeper你可以很方便的开发出一些分布式控制的工具,比如分布式lock, barrier,countDown , Semaphore等,甚至有人使用zookeeper开发了一个分布式Collections.
zookeeper客户端     
      我们构建分布式logserver系统,主要使用zookeeper的目录服务,zookeeper本身有api可供我们来使用zookeeper的一些特性,但是zookeeper的api接口太生硬了,不方便使用,但这么强大的zookeeper肯定有很多公司在使用,他们一定会发现现有api的问题,肯定会出不少优秀的api,于是我们找到了Curator,Curator是Netflix开源的一套ZooKeeper客户端框架. Netflix在使用ZooKeeper的过程中发现ZooKeeper自带的客户端太底层, 应用方在使用的时候需要自己处理很多事情, 于是在它的基础上包装了一下, 提供了一套更好用的客户端框架。
Curator主要解决了三类问题:

    封装ZooKeeper client与ZooKeeper server之间的连接处理;
    提供了一套Fluent风格的操作API;
    提供ZooKeeper各种应用场景(recipe, 比如共享锁服务, 集群领导选举机制)的抽象封装.
    Curator实现的zookeeper的特性有如下这些:
1.jpg
使用Curator
       使用Curator向zookeeper注册logserver,具体代码见logserver的ZooKeeperManager类中的init方法:

2.jpg

使用Curator向zookeeper获取注册到zookeeper中的logserver信息,具体代码见logserver项目ZooLogClient类中的init方法:
3.jpg
具体总结下来,就是使用curator向zookeeper注册logserver,log的客户端再使用curator获取注册的zookeeper信息,当某台logserver当机,zookeeper能通知到log的客户端,以重新获取新的logserver服务。

加微信w3aboutyun,可拉入技术爱好者群

已有(1)人评论

跳转到指定楼层
sun128837 发表于 2014-10-16 17:47:04
有thrift什么事
回复

使用道具 举报

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

本版积分规则

关闭

推荐上一条 /2 下一条