转载自: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. Hbase学习Hbase基础介绍

    一.产生背景 自1970年以来,关系数据库用于数据存储和维护有关问题的解决方案.大数据的出现后,好多公司实现处理大数据并从中受益,并开始选择像Hadoop的解决方案.Hadoop使用分布式文件系统,用 ...

  2. ArrayDeque API 与算法分析

    ArrayDeque 是双端队列的动态数组实现,可以当作栈和队列来使用.作为栈时,它的效率比 Stack 更高,作为队列时,效率比 LinkedList 更高.ArrayDeque 大部分操作的时间复 ...

  3. Debian安装HomeBrew

    前言 HomeBrew 的用处我想使用 Mac 的开发人员都知道, 本篇讲解如何在 Debian 上安装 BrewLinux 更新: 后来发现并不是很好用, 不建议使用 官方推荐的脚本安装 注意这里只 ...

  4. Unity优化图解

    花了2天把之前学到的一些关于优化的知识全都写了下来,放到一张表里面 https://www.processon.com/mindmap/5cf64f53e4b0bc8329e8112e

  5. 【SpringMVC】SpringMVC 入门

    SpringMVC 入门 文章源码 SpringMVC 基本概念 在 JavaEE 开发中,几乎全都是基于 B/S 架构的开发.在 B/S 架构中,系统标准的三层架构包括:表现层.业务层.持久层. 表 ...

  6. 【剑指 Offer】03.数组中重复的数字

    题目描述 找出数组中重复的数字. 在一个长度为 n 的数组 nums 里的所有数字都在 0-n-1 的范围内.数组中某些数字是重复的,但不知道有几个数字重复了,也不知道每个数字重复了几次.请找出数组中 ...

  7. 【Flutter】功能型组件之导航返回拦截

    前言 为了避免用户误触返回按钮而导致APP退出,在很多APP中都拦截了用户点击返回键的按钮,然后进行一些防误触判断,比如当用户在某一个时间段内点击两次时,才会认为用户是要退出(而非误触).Flutte ...

  8. linux最大打开文件句柄数

    linux最大打开文件句柄数,即打开文件数最大限制,就是规定的单个进程能够打开的最大文件句柄数量(Socket连接也算在里面,默认大小1024) liunx中文件句柄有两个限制,一种是用户级的,一种是 ...

  9. 你不知道的Linux目录

    Linux二级目录及其对应的作用 主要文件

  10. ctfhub技能树—信息泄露—hg泄露

    打开靶机 查看页面信息 使用dvcs-ripper工具进行处理 ./rip-hg.pl -v -u http://challenge-cf630b528f6f25e2.sandbox.ctfhub.c ...