转载自: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. 破解版IDM使用问题

    正版的IDM一般下载安装后有30天的免费使用期,过了就需要买正版序列号才能使用,网上一般提供的破解版的IDM安装后又存在无法添加到chrome插件的问题 这里针对这个问题给出解决方案: 首先下载破解版 ...

  2. hashmap有一个loadFactory为什么是0.75从泊松分布解析看看

    简述: 写这篇文章是看到网上的一篇面试题,有面试官问hashmap有一个loadFactory为什么是0.75  我先解释一下 0.75上下文,当一个hashmap初始数组大小暂时不考虑扩容情况,初始 ...

  3. 解决Github下载仓库慢的正确姿势

    上个月刚安装了 Manjaro ,然后最近在Manjaro下载Github的项目竟然只有几十b/s,这能忍?对于下载Github上的代码是硬需求,没办法直接探索一下突破的方法了. 方法一:安装chro ...

  4. 解析SwiftUI布局细节(三)地图的基本操作

    前言 前面的几篇文章总结了怎样用 SwiftUI 搭建基本框架时候的一些注意点(和这篇文章在相同的分类里面,有需要了可以点进去看看),这篇文章要总结的东西是用地图数据处理结合来说的,通过这篇文章我们能 ...

  5. python常用操作和内置函数

    一.常用数据处理方法. 1.索引:按照号码将对应位置的数据取出使用 2.list将任意类型数据用逗号分割存在列表中 3.range:产生一堆数字(顾头不顾尾) 4.切片:可以从复制数据的一部分,不影响 ...

  6. 网页短信平台源码和开发功能介绍 思路和功能 G客短信平台

    G客短信源码介绍 (只介绍现有功能模块文字介绍配系统截图) 一:后台首页 ​ QQ:290615413 VX:290615413

  7. ABP vNext EventBus For RabbitMQ 分布式事件总线使用注意事项_补充官网文档

    [https://docs.abp.io/zh-Hans/abp/latest/Distributed-Event-Bus-RabbitMQ-Integration](ABP vNext官方文档链接) ...

  8. i5 11300h和R5 5600H 的区别 哪个好

    酷睿i5-11300H配置为4个内核及8个线程,具备8MB的L3缓存和5MB的L2缓存,基础频率3.10GHz最高睿频4.40GHz.Intel的显卡将集成Xe GPU内核.至于TDP,i5-1130 ...

  9. 紧急预警】关于爆发的 incaseformat 病毒事件亲身体验

    相关报道 incaseformat病毒 360安全卫士服务号 https://mp.weixin.qq.com/s/KM6esd1eUlBt-YHtEwnfuw 广东省网络安全应急响应平台 https ...

  10. RSA共模攻击

    在安恒月赛中碰到一道密码学方向的ctf题 附上源码 from flag import flag from Crypto.Util.number import * p=getPrime(1024) q= ...