zookeeper是本身是一种分布式协调服务(英文意思动物园园长因为Hadoop就是一个动物园,storm、hadoop、kafkaka、hbaser都是基于zookeeper开发的)

原理:Zookeeper虽然在配置文件中并没有指定master和slave但是,zookeeper工作时,是有一个节点为leader,其他则为follower,Leader是通过内部的选举机制临时产生的。

一、zookeeper是什么(马士兵的说法,言简意赅!)

1、一致:所有用户通过客户端访问的数据全部一致

2、有头:每个zookeeper集群都有一个leader和几个follower(通过PAXOS的选举机制)

Leader 和  follower  只要集群中有半数以上节点存活,集群就能提供服务

3.数据树:树状的储存数据结构(存储类型分为暂时和持久)

数据Znode有两种类型:

短暂(ephemeral)(断开连接自己删除)

持久(persistent)(断开连接不删除)

二、zookeeper的功能

1、管理(存储,读取)用户程序提交的数据;

2、并为用户程序提供数据节点监听服务;

三、作用有哪些

1、集群的配置一致

2、对每台机器和数据进行监听

3.、分布式的负载平衡

4、分布式锁

四、集群的特点

半数机制:集群中半数以上机器存活,集群可用。

zookeeper适合装在奇数台机器上!

五、搭建zookeeper集群的步骤

前提条件JDK安装完毕

  5.1上传及解压

解压:tar -zxvf zookeeper-3.4.5.tar.gz

重命名 : mv zookeeper-3.4.5 zookeeper

  5.2修改环境变量

vim /etc/profile(修改文件)

  #zookeeper环境配置(为了在各种目录都能运行zookeeper命令)

  export ZOOKEEPER_HOME=/home/hadoop/zookeeper(你zookeeper安装路径)

  export PATH=$PATH:$ZOOKEEPER_HOME/bin

wq:保存退出

source /etc/profile :重启配置文件

  5.3修改zookeeper的配置文件

进入conf目录: cd zookeeper/conf

重命名:cp zoo_sample.cfg zoo.cfg

vim zoo.cfg

dataDir=/home/hadoop/zookeeper/data(创建路径保存数据)

dataLogDir=/home/hadoop/zookeeper/log(创建数据保存日志)

server.1=slave1:2888:3888 (主机名, 心跳端口、数据端口)

server.2=slave2:2888:3888

server.3=slave3:2888:3888

wq:保存退出

创建刚才配置文件的目录

cd /home/hadoop/zookeeper/

mkdir -m 755 data

mkdir -m 755 log

  5.4在data文件夹下新建myid文件,myid的文件内容为:

cd data

vi myid

1(对应子机的编号)

wq:退出

scp -r /home/hadoop/zookeeper root@slave2:/home/hadoop/

scp -r /home/hadoop/zookeeper root@slave3:/home/hadoop/

到slave2上:修改myid为:2

到slave3上:修改myid为:3

   5.5启动测试

zkServer.sh start

jps(查看进程)

zkServer.sh status(查看集群状态,主从信息)

五、zookeeper客户端操作

运行 zkCli.sh –server <ip>进入命令行工具

1、查看当前 ZooKeeper 中所包含的内容

ls /

2、创建 :这个命令创建了一个新的 znode 节点“ zk ”以及与它内容:

create /zk "myData“

3、我们运行 get 命令来确认 znode 是否有内容:

[zk: 202.115.36.251:2181(CONNECTED) 3] get /zk

#监听这个节点的变化,当另外一个客户端改变/zk时,它会打出下面的

get /zk watch

4、下面我们通过 set 命令来对 zk 所关联的字符串进行设置:

[zk: 202.115.36.251:2181(CONNECTED) 4] set /zk "zsl“

5、znode 删除:只能删一个

[zk: 202.115.36.251:2181(CONNECTED) 5] delete /zk

6、删除所有子节点:rmr

[zk: 202.115.36.251:2181(CONNECTED) 5] rmr /zk

3.0 zookeeper的集群介绍、搭建、环境、安装的更多相关文章

  1. Zookeeper服务器集群的搭建与操作

    ZooKeeper 作用:Zookeeper 可以用来保证数据在zk集群之间的数据的事务性一致(原子操作). 介绍:Zookeeper 是 Google 的 Chubby一个开源的实现,是 Hadoo ...

  2. zookeeper以及集群的搭建

    今天我来写一写zookeeper集群的搭建流程 1.zookeeper的搭建不难,难的是对他的理解以及良好的使用.单机版的zookeeper只需要解压后直接命令 启动即可 解压zookeeper,ta ...

  3. zookeeper伪集群的搭建

    由于公司服务器数量的限制,我们往往没有那么多的服务器用来搭建zookeeper的集群,所以产生了伪集群的搭建,也就是将多个zookeeper搭建在同一台机器上. 准备工作: 1,一台服务器,我们这里用 ...

  4. zookeeper的集群介绍、搭建、环境、安装

    zookeeper是本身是一种分布式协调服务(英文意思动物园园长因为Hadoop就是一个动物园,storm.hadoop.kafkaka.hbaser都是基于zookeeper开发的) 原理:Zook ...

  5. Spark3.0.1各种集群模式搭建

    对于spark前来围观的小伙伴应该都有所了解,也是现在比较流行的计算框架,基本上是有点规模的公司标配,所以如果有时间也可以补一下短板. 简单来说Spark作为准实时大数据计算引擎,Spark的运行需要 ...

  6. ZooKeeper伪集群的搭建(Windows)

    首先下载 zookeeper 地址:https://www.apache.org/dyn/closer.cgi/zookeeper/ 1.下载完成解压后修改文件夹名字为zookeeper1,然后删除c ...

  7. oracle 集群RAC搭建--环境准备

    一,环境介绍 目前我本身环境已经有DG,正在尝试重做搭建.如需完成请移步往期文章--搭建DG

  8. 关于Hadoop集群的搭建环境变量相关配置

    在任何路径下输入HDFS中的命令都可以进行shell操作的配置: 要设置环境变量: (1) # vim /etc/profile在profile文件下面追加写入下面信息 export HADOOP_H ...

  9. zookeeper介绍及集群的搭建(利用虚拟机)

    ZooKeeper ​ ZooKeeper是一个分布式的,开放源码(apache)的分布式应用程序协调服务,是Google的Chubby一个开源的实现,是Hadoop和Hbase.dubbox.kaf ...

随机推荐

  1. HDU 1004 Let the Balloon Rise(map的使用)

    传送门: http://acm.hdu.edu.cn/showproblem.php?pid=1004 Let the Balloon Rise Time Limit: 2000/1000 MS (J ...

  2. IIS - 虚拟目录与应用程序的异同

    在Windows 7 IIS7中,对服务器建立站点后,有二种添加子站点的方式 A. 虚拟目录 B. 应用程序   简单总结下二者之间的异同 A.虚拟目录     虚拟目录是指在站点下建立一个虚拟子目录 ...

  3. Redhat7.2 ----team网卡绑定

    我先声明一下,team和bonding是一样的作用,只不过team多了几项功能bonding没有, 做team我们要最少准备两个网卡,我们这里主要显示主备模式. 首先我们先把网卡配置文件删除 nmcl ...

  4. 数据库事务ACID特性及隔离级别

    数据库ACID特性介绍 1.原子性(Atomic)一个事务被视为一个不可分割的最小工作单元,这个事务里的所有操作要么全部成功执行,要么全都不执行,不能只执行其中的一部分操作.实现事务的原子性,要支持回 ...

  5. .net core 实践笔记(二)--EF连接Azure Sql

    ** 温馨提示:如需转载本文,请注明内容出处.** 本文链接:https://www.cnblogs.com/grom/p/9902098.html 笔者使用了常见的三层架构,Api展示层注入了Swa ...

  6. 推荐一个Oracle数据库学习网站

    推荐一个我个人的Oracle数据库学习网站,比较系统性的整理,会持续更新的网站.网址: Oracle基础教程: http://www.oraclejsq.com/article/010100110.h ...

  7. DBA手记(学习)-RAC环境下GES TX报警情况处理

    GES ... TX-... GES的全称是Global Enqueue Service,用于RAC环境的全局共享队列.从提示信息可以看出,目前的锁定是DML引发的行级锁(TX). 检查v$lock_ ...

  8. [iOS]为git设置代理

    查看本地git配置信息 git config --global -e 查看自己***的代理地址和端口信息 为git添加代理 git config --global http.proxy https:/ ...

  9. 微信小程序 - bindtap等事件传参

    什么是事件事件是视图层到逻辑层的通讯方式. 事件可以将用户的行为反馈到逻辑层进行处理. 事件可以绑定在组件上,当达到触发事件,就会执行逻辑层中对应的事件处理函数. 事件对象可以携带额外信息,如 id, ...

  10. Hadoop源码学习笔记之NameNode启动场景流程四:rpc server初始化及启动

    老规矩,还是分三步走,分别为源码调用分析.伪代码核心梳理.调用关系图解. 一.源码调用分析 根据上篇的梳理,直接从initialize()方法着手.源码如下,部分代码的功能以及说明,已经在注释阐述了. ...