转载自:YBCarry

一、ZooKeeper

1.1 zookeeper作用

  • 存储+监听

1.2 zookeeper角色

  • 主从结构

1)Leader领导者->主

2)Follower追随者->从

3)zookeeper由一个领导者多个追随者组成

**zookeeper集群中只要有半数以上的节点存活,zookeeper集群就能正常工作。(高可用)**所以搭建zk集群最好搭建奇数台(3,5,11)。

1.3 zookeeper功能

大数据中使用zookeeper业务:

  • 1)做统一的配置管理
  • 2)做统一的命名服务
  • 3)做统一的集群管理
  • 4)做服务器的动态上下线感知(代码)

二、集群规划

  1. hadoop01、hadoop02和hadoop03三个节点上部署ZooKeeper。
  2. 上传安装包zookeeper-3.4.10.tar.gz
  3. 具备java环境

三、安装流程

(1)单节点安装——hadoop01

解压zookeeper安装包到目标目录下:

$ tar -zxvf zookeeper-3.4.10.tar.gz -C 目标目录

在zookeeper的根目录zookeeper-3.4.10/下创建zkData:

$ mkdir -p zkData

重命名zookeeper-3.4.10/conf目录下的zoo_sample.cfg为zoo.cfg作为配置文件:

$ mv zoo_sample.cfg zoo.cfg

(2)配置zoo.cfg文件

修改dataDir路径为创建的zkData路径:

 dataDir=/XXXXXX/zookeeper-3.4.10/zkData

增加集群信息:

  #######################cluster##########################
server.1=hadoop01:2888:3888
server.2=hadoop02:2888:3888
server.3=hadoop03:2888:3888
  • 2888:zookeeper服务之间通信端口
  • 3888:zookeeper选举机制端口
  • 2181:zookeeper客户端用于连接zookeeper服务器

(3)配置参数解读

Server.A=B:C:D。

  • A是一个数字,表示这个是第几号服务器;
  • B是这个服务器的ip地址;
  • C是这个服务器与集群中的Leader服务器交换信息的端口;
  • D是万一集群中的Leader服务器挂了,需要一个端口来重新进行选举,选出一个新的Leader,而这个端口就是用来执行选举时服务器相互通信的端口。

集群模式下配置一个文件myid,这个文件在dataDir目录下,这个文件里面有一个数据就是A的值,Zookeeper启动时读取此文件,拿到里面的数据与zoo.cfg里面的配置信息比较从而判断到底是哪个server。

(4)集群操作

  • 在zookeeper-3.4.10/zkData目录下创建一个myid的文件:
touch myid
  • 编辑myid文件:(注意myid除编号外不能有任何多余内容,包括空格和空行) vi myid 在文件中添加与server对应的编号:如1
  • 拷贝配置好的zookeeper到其他机器上
    scp -r zookeeper-3.4.10/ hadoop02:$PWD
scp -r zookeeper-3.4.10/ hadoop03:$PWD
  • 分别修改myid文件中内容为2、3

(5)选举机制

四、命令行操作

(1)配置环境变量:

修改配置文件:

vi /etc/profile

增加以下内容:

export ZOOKEEPER_HOME=zookeeper安装路径
export PATH=ZOOKEEPER_HOME/bin

声明环境变量:

source /etc/profile

(2)启动zookeeper集群

$ bin/zkServer.sh start

(3)查看zookeeper状态

$ bin/zkServer.sh status

(4)启动客户端

$ bin/zkCli.sh

(5)退出客户端

$ quit

(6)连接其它机器客户端操作

$ connect 主机名:2181

(7)查看历史操作记录

$ history

(8)查看当前节点的内容

$ ls /

(9)创建节点

$ create /节点名 数据信息

(10)查看节点的值

$ get /节点名

(11)创建节点的可选项

$ create [-s] [-e] path data acl
  • [-e] 短暂节点,退出客户端后消失。
  • [-s] 序号,可创建节点名相同的节点,序号依次累加。

(12)修改节点值

$ set path data [version]
  • [version] 版本
  • 注意:设置版本号 必须从0开始

(13)删除节点

$ delete path

(14)创建子节点

$ create /节点名/子节点名 数据信息

(15)递归删除

$ rmr /节点名

(16)监听

获得监听:

$ get path watch

获得当前节点下增减变化:

$ ls path watch

(17)查看当前节点状态

$ stat /节点名

五、节点状态信息

  • czxid:zookeeper事务id
  • ctime:节点创建时间
  • mZxid:最后更新的
  • czxid mtime:最后修改的时间
  • pZxid:最后更新子节点的czxid
  • cversion:子节点的变化号、子节点修改次数
  • dataVersion:数据变化号
  • aclVersion:访问控制列表的变化号
  • ephemeralOwner:临时节点判断
  • dataLength:节点数据长度
  • numChildren:子节点个数

Linux环境ZooKeeper安装配置及使用的更多相关文章

  1. Linux环境Hive安装配置及使用

    Linux环境Hive安装配置及使用 一.Hive Hive环境前提 二.Hive架构原理解析 三.Hive-1.2.2单机安装流程 (1) 解压apache-hive-1.2.2-bin.tar.g ...

  2. Linux环境Hadoop安装配置

    Linux环境Hadoop安装配置 1. 准备工作 (1)linux配置IP(NAT模式) (2)linux关闭防火墙 (3)设置主机名 (4)设置映射 (5)设置免密登录 2. 安装jdk (1)上 ...

  3. ubuntu linux环境下安装配置jdk和tomcat

    关于linux搭建服务器,ubuntu中jdk和tomcat的安装和配置 一.jdk的安装配置 1:去官网下载好自己需要的版本,注意,linux压缩文件通常以tar.gz结尾,别下载错了.本次我下载安 ...

  4. Linux环境下安装配置Mysql

    首先我们的使用的是linux的 centOS6 版本 安装mysql: 1.查看有没有安装包 yum list mysql* 2.进行安装mysql:一般我们在服务器端安装的都是服务端( mysql- ...

  5. Linux 环境下安装配置 TigerVNC Server 并启用当前会话远程服务(X0VNC)

    曾经喜欢用 RealVNC Server 实现 Linux/Windows 的远程控制,因为 RealVNC 为收费商业软件,支持文件传输,性能优化方面也做得不错.但 RealVNC 从 5.0 版本 ...

  6. Linux环境下安装配置vsftpd服务(三种认证模式)

    一.FTP简介 文件传输协议(英文:File Transfer Protocol,缩写:FTP)是用于在网络上进行文件传输的一套标准协议.它工作于网络传输协议的应用层,使用客户/服务器模式,主要是用来 ...

  7. Linux环境下安装配置JDK1.8

    最近在搞虚拟机,记录下虚拟机内java环境的搭建流程 一.下载合适版本的jdk 此处选择JDK1.8,各位同学可以根据自己的需求选择对应的版本,下载地址为: https://www.oracle.co ...

  8. 1. VMware搭建Linux环境,安装配置centos6.5

    1. 安装VMware,后新建虚拟机 2. 为我们的虚拟机挂载操作系统 3.开启我们的虚拟机,为我们的虚拟机进行安装操作系统 4.配置虚拟机连接网络 修改linux的mac地址 修改mac地址配置文件 ...

  9. Linux环境jdk安装配置

    1.jdk安装包:jdk-8u191-linux-x64.tar.gz2.拷贝 jdk-8u191-linux-x64.tar.gz 到/usr/local命令如下:cp jdk-8u191-linu ...

随机推荐

  1. Kali实现靶机远程控制

    任务一.使用netcat建立监听并连接 1.          在ubuntu开启本地监听,在kali中连接 2.          在kali中开启监听,在ubuntu中反弹连接 任务二.使用met ...

  2. 第十一章节 BJROBOT PS3 手柄控制【ROS全开源阿克曼转向智能网联无人驾驶车】

    1.把小车架空平放在地板上.   2.用 USB 线将 PS3 蓝牙手柄连接至小车主控端,初次连接手柄上的 4 个红色指示灯会同时闪烁; 3.按下手柄中间的圆形配对键,然后等待红灯闪烁至停止. 4.此 ...

  3. git merge了错误分支,如何优雅的回退到merge前的状态?

    git merge了错误分支,如何优雅的回退到merge前的状态? 没push的话 git reset --hard (a分支5点那个时候commit之后的sha1) 然后重新 git merge

  4. hive2

    4.hive优化 1)跑sql的时候会出现的参数: In order to change the average load for a reducer (in bytes): set hive.exe ...

  5. JS 学习 一

  6. netty核心组件之EventLoopGroup和EventLoop

    这节我们着重介绍netty最为核心的组件EventLoopGroup和EventLoop EventLoopGroup:顾名思义就是EventLoop的组,下面来看它们的继承结构 在netty中我们可 ...

  7. Python使用urllib,urllib3,requests库+beautifulsoup爬取网页

    Python使用urllib/urllib3/requests库+beautifulsoup爬取网页 urllib urllib3 requests 笔者在爬取时遇到的问题 1.结果不全 2.'抓取失 ...

  8. SQL注入之堆叠注入(堆查询注入)

    Stached injection -- 堆叠注入 0x00 堆叠注入的定义 ​ Stacked injection 汉语翻译过来后,称 为堆查询注入,也有称之为堆叠注入.堆叠注入为攻击者提供了很多的 ...

  9. .NET 云原生架构师训练营(模块二 基础巩固 RabbitMQ Masstransit 异常处理)--学习笔记

    2.6.8 RabbitMQ -- Masstransit 异常处理 异常处理 其他 高级功能 异常处理 异常与重试 重试配置 重试条件 重新投递信息 信箱 异常与重试 Exception publi ...

  10. 有了链路日志增强,排查Bug小意思啦!

    在工作中,相信大家最怕的一件事就是听到有人在工作群艾特你:某某功能报错啦... 然后你就得屁颠屁颠的去服务器看日志,日志量少还好点,多的话找起来太麻烦了.不太容易直接定位到关键地方. 东找找西找找,好 ...