zoukankan      html  css  js  c++  java
  • ZooKeeper安装与运行

    ZooKeeper安装与运行

    首先从官网下载ZooKeeper压缩包,然后解压下载得到的ZooKeeper压缩包,发现有“bin,conf,lib”等目录。“bin目录”中存放有运行脚本;“conf目录”中存放有配置文件;“lib目录”中存放有运行所需要第三方库。

    一、standalone模式

    1.1、编辑配置文件

    在“conf”目录下,新建一个名为“zoo.cfg”的文件,其中内容如下:

    tickTime=2000
    dataDir=/home/dsl/tmp/zookeeper
    clientPort=2181
    • 1
    • 2
    • 3
    • 1
    • 2
    • 3

    1.2、运行ZooKeeper Server

    执行bin/zkServer.sh start命令,运行ZooKeeper Server进程,得到如图1所示结果,表示后台运行ZooKeeper Server进程成功。

    图1 
    这里写图片描述

    也可以执行bin/zkServer.sh start-foreground命令,非后台运行ZooKeeper Server进程,得到如图2所示结果。

    图2 
    这里写图片描述

    1.3、运行ZooKeeper命令行客户端

    执行bin/zkCli.sh -server 127.0.0.1:2181命令,运行ZooKeeper命令行客户端,得到如图3所示界面,可以在其中调用操作Znode节点树的API。

    图3 
    这里写图片描述

    1.4、调用操作Znode节点树的API

    进入“1.3、运行ZooKeeper命令行客户端”中得到的界面,调用操作Znode节点树的API。 
    1、获取初始Znode节点 
    初始时,存在路径标识为“/zookeeper”的Znode节点,该Znode节点保存一些元数据,不能被删除。 
    执行ls /命令,可得到如图4所示结果。

    图4 
    这里写图片描述

    2、创建Znode节点 
    执行create /data "data"命令,创建一个Znode节点,路径标识为“/data”,包含内容“data”。再执行ls /命令,得到如图5所示结果。

    图5 
    这里写图片描述

    3、删除Znode节点 
    执行delete /data命令,删除路径标识为“/data”的Znode节点。再执行ls /命令,得到如图6所示结果。

    图6 
    这里写图片描述

    二、quorum模式

    使用quorum模式有两种形式:1)使用多台机器,在每台机器上运行一个ZooKeeper Server进程;2)使用一台机器,在该台机器上运行多个ZooKeeper Server进程。在生产环境中,一般使用第一种形式,在练习环境中,一般使用第二种形式。

    2.1、参数配置

    quorum模式下,要使一个ZooKeeper Server进程能够正常运行,需要配置一些参数,以下是常见的一些参数。 
    1、data目录 
    用于存放进程运行数据。 
    2、data目录下的myid文件 
    用于存储一个数值,该数值用来作为该ZooKeeper Server进程的标识。 
    3、监听Client端请求的端口号 
    该端口号用来监听Client端请求。(关于“Client”见《ZooKeeper》 Chapter 2 Getting to Grips with ZooKeeper的图2) 
    4、监听同ZooKeeper集群内其他ZooKeeper Server进程通信请求的端口号 
    该端口号用来监听同ZooKeeper集群内其他ZooKeeper Server进程的通信请求。 
    5、监听ZooKeeper集群内“leader”选举请求的端口号 
    该端口号用来监听ZooKeeper集群内“leader”选举的请求。注意这个是ZooKeeper集群内“leader”的选举,跟分布式应用程序无关。

    参数配置注意事项: 
    1)同一个ZooKeeper集群内,不同ZooKeeper Server进程的标识需要不一样,即myid文件内的值需要不一样 
    2)采用上述第2种形式构建ZooKeeper集群,需要注意“目录,端口号”等资源的不可共享性,如果共享会导致ZooKeeper Server进程不能正常运行,比如“data目录,几个监听端口号”都不能被共享

    2.2、举例

    采用上述第2种形式构建一个使用quorum模式的ZooKeeper集群,集群规划如表1所示。

    表1

    ZooKeeper Server进程标识(myid文件内数值)data目录监听Client端请求的端口号监听同ZooKeeper集群内其他ZooKeeper Server进程通信请求的端口号监听ZooKeeper集群内“leader”选举请求的端口号配置文件名称
    1 /home/dsl/bigdisk/apps/zookeeper-3.4.8/deploy/z1/data 2181 2222 2223 z1.cfg
    2 /home/dsl/bigdisk/apps/zookeeper-3.4.8/deploy/z2/data 2182 3333 3334 z2.cfg
    3 /home/dsl/bigdisk/apps/zookeeper-3.4.8/deploy/z3/data 2183 4444 4445 z3.cfg

    相应的目录结构如图1所示。

    图1 
    这里写图片描述

    “z1.cfg,z2.cfg,z3.cfg”这3个文件的文件内容分别如下所示。

    # z1.cfg
    tickTime=2000
    initLimit=10
    syncLimit=5
    
    dataDir=/home/dsl/bigdisk/apps/zookeeper-3.4.8/deploy/z1/data
    clientPort=2181
    # server.x中的“x”表示ZooKeeper Server进程的标识
    # 同一个ZooKeeper集群内的ZooKeeper Server进程间的通信不仅可以使用具体的点IP地址,也可以使用组播地址
    server.1=127.0.0.1:2222:2223
    server.2=127.0.0.1:3333:3334
    server.3=127.0.0.1:4444:4445
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    # z2.cfg
    tickTime=2000
    initLimit=10
    syncLimit=5
    
    dataDir=/home/dsl/bigdisk/apps/zookeeper-3.4.8/deploy/z2/data
    clientPort=2182
    # server.x中的“x”表示ZooKeeper Server进程的标识
    # 同一个ZooKeeper集群内的ZooKeeper Server进程间的通信不仅可以使用具体的点IP地址,也可以使用组播地址
    server.1=127.0.0.1:2222:2223
    server.2=127.0.0.1:3333:3334
    server.3=127.0.0.1:4444:4445
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    # z3.cfg
    tickTime=2000
    initLimit=10
    syncLimit=5
    
    dataDir=/home/dsl/bigdisk/apps/zookeeper-3.4.8/deploy/z3/data
    clientPort=2183
    # server.x中的“x”表示ZooKeeper Server进程的标识
    # 同一个ZooKeeper集群内的ZooKeeper Server进程间的通信不仅可以使用具体的点IP地址,也可以使用组播地址
    server.1=127.0.0.1:2222:2223
    server.2=127.0.0.1:3333:3334
    server.3=127.0.0.1:4444:4445
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12

    2.2.1、运行ZooKeeper Server

    分别执行bin/zkServer.sh start deploy/z1/z1.cfgbin/zkServer.sh start deploy/z2/z2.cfgbin/zkServer.sh start deploy/z3/z3.cfg命令,运行上述配置的3个ZooKeeper Server进程。

    2.2.2、运行ZooKeeper命令行客户端

    执行bin/zkCli.sh -server 127.0.0.1:2181,127.0.0.1:2182,127.0.0.1:2183命令,建立ZooKeeper Client端到ZooKeeper集群的连接会话。

    2.2.3、调用操作Znode节点树的API

    跟“1.4、调用操作Znode节点树的API”一样,可以在“2.2.2、运行ZooKeeper命令行客户端”中得到的界面内,调用操作Znode节点树的API。



    备注: 
    根据《ZooKeeper》 Chapter 2 Getting to Grips with ZooKeeper可知,“ZooKeeper命令行客户端”本质上还是使用了Java版驱动程序库提供的API或者C版驱动程序库提供的API。 


    参考文献: 
    [1]https://zookeeper.apache.org/doc/r3.4.8/zookeeperStarted.html 
    [2]http://blog.csdn.net/dslztx/article/details/51077606

  • 相关阅读:
    python学习:两个py文件间的函数调用
    python学习:基础概念
    python学习:Windows 下 Python easy_install 的安装
    Python学习:python网址收集
    Nginx模块之Nginx-Ts-Module学习笔记(一)抢险体验
    PHP 文件加密Zend Guard Loader 学习和使用(如何安装ioncube扩展对PHP代码加密)
    OpenResty 扩展库(二)lua-resty-template
    Github 开源项目(二) jsmpeg-vnc
    info replication
    linux下编译make文件报错“/bin/bash^M: 坏的解释器,使用grep快速定位代码位置
  • 原文地址:https://www.cnblogs.com/Leo_wl/p/5458265.html
Copyright © 2011-2022 走看看