zookeeper入门学习

1、基本概念

ZooKeeper是一个分布式的,开放源码的分布式应用程序协调服务,是Google的Chubby一个开源的实现,是Hadoop和Hbase的重要组件。它是一个为分布式应用提供一致性服务的软件,提供的功能包括:配置维护、域名服务、分布式同步、组服务等。

Zookeeper是高性能、高可用的分布式协调框架,采用了自定义的ZAB(Zookeeper Atomic Broadcast)事务一致性协议,在高并发分布式系统环境中保证事务一致性。ZK采用类似Linux操作系统文件目录结构管理节点,节点数据常驻内存,避免磁盘I/O影响性能,并提供对用户透明的持久化功能保证数据安全。ZK适用于小量数据、高性能、高并发的应用场景。

2、zk提供的服务

(1)命名服务

服务提供方在zk上创建一个临时的node,且该node是全局唯一的。服务消费方通过读取zk上的临时Node节点获取到服务提供方提供的信息,进而就可以调用服务提供者提供的服务。实例:阿里的dubbo就是采用zk作为注册中心。

(2)发布订阅服务

发布订阅模型,即配置中心,可将应用可配置项发布到ZK上,供订阅者动态获取配置,同一集群使用同一套配置,实现配置集中、动态管理,避免修改配置后重启应用服务。

(3)负载均衡

在分布式系统中,在一个集群中的由多台服务器提供服务。为了使每一台服务器负载更加均衡,需要根据服务负载的情况进行请求分发的框架。而ZK就是这样的,可以动态的注册和发现服务,是服务更透明。

(4)分布协调/通知

(5)分布式锁

zk具有事务强一致性

锁服务分为独占锁时序锁
独占锁:多个服务器同时在ZK上创建一个节点,创建成功者即获取锁成功。

(6)分布式队列服务

分布式队列分为两种:
先进先出队列FIFO,与分布式时序锁的使用原理一致。
控制队列元素数量,等待队列中成员数量到达指定值之后,方可开始执行下一步处理操作。

内容来自:http://newliferen.github.io/2015/07/24/ZooKeeper%E5%85%A5%E9%97%A8/

时间: 2024-12-25 01:26:17

zookeeper入门学习的相关文章

zookeeper入门学习(一)

概述: ZooKeeper是Hadoop的开源子项目(Google Chubby的开源实现),它是一个针对大型分布式系统的可靠协调系统,提供的功能包括:配置维护.命名服务.分布式同步.组服务等. Zookeeper中的角色主要有以下三类,如下表所示: Leader主要有三个功能: 恢复数据: 维持与Learner的心跳,接收Learner请求并判断Learner的请求消息类型: Learner的消息类型主要有PING消息.REQUEST消息.ACK消息.REVALIDATE消息,根据不同的消息类

zookeeper入门学习(二)

zookeeper安装 单机模式 首先,下载zookeeper-3.4.8.tar.gz 创建/usr/zookeeper,解压到zookeeper目录 [[email protected] zookeeper]# tar -zxvf zookeeper-3.4.8.tar.gz 配置环境变量: 为了今后操作方便,我们需要对Zookeeper的环境变量进行配置,方法如下在/etc/profile文件中加入如下内容: [[email protected] liutie]# vi /etc/prof

Retrofit 入门学习

Retrofit 入门学习官方RetrofitAPI 官方的一个例子 public interface GitHubService { @GET("users/{user}/repos") Call<List<Repo>> listRepos(@Path("user") String user); } 这些注解都有一个参数 value,用来配置其路径,比如示例中的 users/{user}/repos, 我们还注意到在构造 Retrofit

JavaSE入门学习21:Java面向对象之接口(interface)(二)

一接口实现的多态 在上一篇博文:JavaSE入门学习20:Java面向对象之接口(interface)(一)中提到了接口的实现存在多态性,那么 这一篇主要就要分析接口实现的多态. 实例一 Test.java源文件代码: public class Test{ public static void main(String[] args){ //实现接口Singer Singer s1 = new Student("Amy"); s1.sing(); s1.sleep(); s1.study

[Todo] Nodejs学习及Spider实验(包括php入门学习、React入门学习)

/Users/baidu/Documents/Data/Interview/Web-Server开发 深入浅出Node.js-f46c http://blog.csdn.net/u012273376/article/details/52736906 利用nodejs做爬虫 http://www.runoob.com/nodejs/nodejs-callback.html nodejs学习之路 http://www.runoob.com/php/php-tutorial.html php学习之路

JavaSE入门学习24:Java面向对象补充

一Java中的Object类 Object类是所有Java类的父类,如果一个类没有使用extends关键字明确标识继承另外一个类,那么这个类默认 继承Object类. public class Person{ // } //等价于 public class Person extends Object{ // } Object类中的方法,适合所有子类. 1)toString()方法 在Object类中定义有public String toString()方法,其返回值是String类型,描述当前对

js入门学习

在HTML,CSS学习的最后,开始入门学习javascript, 首先就是去了解它的用途 作用:使web页面能够与用户交互,作为控制浏览器给网页增添活力的方法 定义:它是一种脚本语言,作用于浏览器.和java没有半毛钱关系,主要是当时Netscape公司为了增加影响力改了名,,(是不是感觉很无耻) ps:区分程序的一种方式:1.客户端程序(client-side),像javascript就是,我觉得HTML,CSS应该也是. 2.服务器端程序(server-side),java,perl,php

mybatis入门学习

一.mybaits简介 java程序中常用的数据库框架. 二.mybait入门学习 1.环境 创建一个java或者javaweb项目:我是创建了一个structs项目,helloworld 2.添加相应的jar包

angularjs入门学习【指令篇】

一.首先我们来了解下指令API 属性 含义 restrict 申明标识符在模版中作为元素,属性,类,注释或组合,如何使用 priority 设置模版中相对于其他标识符的执行顺序 Template 指定一个字符串式的内嵌模版,如果你指定了模版是一个URL,那么是不会使用的 tempateUrl 指定URL加载的模版,如果你已经指定了内嵌的模版字符串,那么它不会使用的 Replace 如果为真,替换当前元素,如果是假或未指定,拼接到当前元素 Transclude 移动一个标识符的原始字节带你到一个新