ZooKeeper客户端命令行操作

  1. 启动服务端

    [simon@hadoop102 zookeeper-3.4.10]$ bin/zkServer.sh start
  2. 查看状态信息

    Using config: /opt/module/zookeeper-3.4.10/bin/../conf/zoo.cfg
    Starting zookeeper ... STARTED
    [simon@hadoop102 zookeeper-3.4.10]$ bin/zkServer.sh status
    ZooKeeper JMX enabled by default
    Using config: /opt/module/zookeeper-3.4.10/bin/../conf/zoo.cfg
    Mode: follower
  3. 启动客户端

    [simon@hadoop102 zookeeper-3.4.10]$ bin/zkCli.sh
  4. 查看当前znode中所包含的内容

    [zk: localhost:2181(CONNECTED) 1] ls /
    [zookeeper]
  5. 查看当前节点的详细数据

    [zk: localhost:2181(CONNECTED) 2] ls2 /
    [zookeeper]
    cZxid = 0x0
    ctime = Thu Jan 01 08:00:00 CST 1970
    mZxid = 0x0
    mtime = Thu Jan 01 08:00:00 CST 1970
    pZxid = 0x0
    cversion = -1
    dataVersion = 0
    aclVersion = 0
    ephemeralOwner = 0x0
    dataLength = 0
    numChildren = 1
  6. 分别创建两个普通节点

    [zk: localhost:2181(CONNECTED) 3] create /simon "user"
    [zk: localhost:2181(CONNECTED) 0] create /simon/a "a"
    Created /simon/a
  7. 获得节点的值

    [zk: localhost:2181(CONNECTED) 1] get /simon
    user
    cZxid = 0x100000004
    ctime = Thu Oct 24 21:59:31 CST 2019
    mZxid = 0x100000004
    mtime = Thu Oct 24 21:59:31 CST 2019
    pZxid = 0x100000007
    cversion = 1
    dataVersion = 0
    aclVersion = 0
    ephemeralOwner = 0x0
    dataLength = 4
    numChildren = 1 [zk: localhost:2181(CONNECTED) 2] get /simon/a
    a
    cZxid = 0x100000007
    ctime = Thu Oct 24 22:19:10 CST 2019
    mZxid = 0x100000007
    mtime = Thu Oct 24 22:19:10 CST 2019
    pZxid = 0x100000007
    cversion = 0
    dataVersion = 0
    aclVersion = 0
    ephemeralOwner = 0x0
    dataLength = 1
    numChildren = 0
  8. 创建临时节点

    [zk: localhost:2181(CONNECTED) 3] create -e /simon/temp "temp"
    Created /simon/temp

    (1)在客户端可以查看到

    [zk: localhost:2181(CONNECTED) 5] ls /simon
    [a, temp]

    (2)退出当前客户端之后再重启客户端

    [zk: localhost:2181(CONNECTED) 6] quit
    Quitting...
    2019-10-24 22:22:00,789 [myid:] - INFO [main:ZooKeeper@684] - Session: 0x26dfe0bc0f60002 closed
    2019-10-24 22:22:00,790 [myid:] - INFO [main-EventThread:ClientCnxn$EventThread@519] - EventThread shut down for session: 0x26dfe0bc0f60002 [simon@hadoop102 zookeeper-3.4.10]$ bin/zkCli.sh

    (3)再次查看根目录下临时节点已经被删除

    [zk: localhost:2181(CONNECTED) 0] ls /simon
    [a]
  9. 创建带序号的节点

    (1)先创建一个普通的根节点/simon/b

    [zk: localhost:2181(CONNECTED) 1] create /simon/b "b"
    Created /simon/b

    (2)创建一个带序号的节点

    [zk: localhost:2181(CONNECTED) 1] create -s /simon/b/ba "ba"
    Created /simon/b/ba0000000001
    [zk: localhost:2181(CONNECTED) 2] create -s /simon/b/bb "bb"
    Created /simon/b/bb0000000002
    [zk: localhost:2181(CONNECTED) 3] create -s /simon/b/bc "bc"
    Created /simon/b/bc0000000003

    如果原来没有节点序号,序号从0开始依次递增。如果原节点下已经有2个节点,则再排序时从2开始,以此类推。

  10. 修改节点数据的值

    [zk: localhost:2181(CONNECTED) 4] set /simon/b "B"
    
    [zk: localhost:2181(CONNECTED) 5] get /simon/b
    [zk: localhost:2181(CONNECTED) 5] get /simon/b
    B
    cZxid = 0x10000000b
    ctime = Thu Oct 24 22:23:07 CST 2019
    mZxid = 0x100000012
    mtime = Thu Oct 24 22:26:16 CST 2019
    pZxid = 0x100000011
    cversion = 4
    dataVersion = 1
    aclVersion = 0
    ephemeralOwner = 0x0
    dataLength = 1
    numChildren = 4
  11. 节点值的变化监听

    (1)在Hadoop104主机上注册监听/simon节点数据的变化

    [zk: localhost:2181(CONNECTED) 0] get /simon watch    #监听根节点用:get 子节点:ls
    user
    cZxid = 0x100000004
    ctime = Thu Oct 24 21:59:31 CST 2019
    mZxid = 0x100000004
    mtime = Thu Oct 24 21:59:31 CST 2019
    pZxid = 0x10000000b
    cversion = 4
    dataVersion = 0
    aclVersion = 0
    ephemeralOwner = 0x0
    dataLength = 4
    numChildren = 2

    (2)在Hadoop103主机上修改/simon节点的数据

    [zk: localhost:2181(CONNECTED) 0] set /simon "hello world"
    cZxid = 0x100000004
    ctime = Thu Oct 24 21:59:31 CST 2019
    mZxid = 0x100000015
    mtime = Thu Oct 24 22:29:32 CST 2019
    pZxid = 0x10000000b
    cversion = 4
    dataVersion = 1
    aclVersion = 0
    ephemeralOwner = 0x0
    dataLength = 11
    numChildren = 2

    (3)在Hadoop104节点上观察数据的变化的监听

    [zk: localhost:2181(CONNECTED) 1]
    WATCHER:: WatchedEvent state:SyncConnected type:NodeDataChanged path:/simon
  12. 节点的子节点变化监听(路劲变化)

    (1)在Hadoop104主机上注册监听/simon节点的子节点变化

    [zk: localhost:2181(CONNECTED) 0] ls /simon watch
    [a, b]

    (2)在Hadoop103主机/simon节点创建子节点

    [zk: localhost:2181(CONNECTED) 4] create /simon/c "c"
    Created /simon/c

    (3)观察Hadoop104主机收到的子节点变化的监听

    [zk: localhost:2181(CONNECTED) 4] ls /simon watch
    WATCHER:: WatchedEvent state:SyncConnected type:NodeChildrenChanged path:/simon
  13. 删除节点

    [zk: localhost:2181(CONNECTED) 6] delete /simon/b/bd
    
    
  14. 递归删除节点

    [zk: localhost:2181(CONNECTED) 7] rmr /simon/b      
    
    
  15. 查看节点的状态

    [zk: localhost:2181(CONNECTED) 8] stat /simon
    cZxid = 0x100000004
    ctime = Thu Oct 24 21:59:31 CST 2019
    mZxid = 0x100000015
    mtime = Thu Oct 24 22:29:32 CST 2019
    pZxid = 0x100000021
    cversion = 6
    dataVersion = 1
    aclVersion = 0
    ephemeralOwner = 0x0
    dataLength = 11
    numChildren = 2

ZooKeeper学习笔记(四)——shell客户端命令操作的更多相关文章

  1. ZooKeeper学习笔记四:使用ZooKeeper实现一个简单的分布式锁

    作者:Grey 原文地址: ZooKeeper学习笔记四:使用ZooKeeper实现一个简单的分布式锁 前置知识 完成ZooKeeper集群搭建以及熟悉ZooKeeperAPI基本使用 需求 当多个进 ...

  2. Zookeeper学习笔记——2 Shell和Java API的使用

    ZooKeeper的使用一般都接触不到,因为平时工作甚少直接使用ZK.但是通过手动操作一下ZK,还是能对其中的门道了解各一二. shell 常用命令 help 查看所有支持的命令 [zk: local ...

  3. SQL学习笔记四之MySQL数据操作

    阅读目录 一 介绍 二 插入数据INSERT 三 更新数据UPDATE 四 删除数据DELETE 五 查询数据SELECT 六 权限管理 一 介绍 MySQL数据操作: DML =========== ...

  4. 吴裕雄--天生自然ShellX学习笔记:Shell test 命令

    Shell中的 test 命令用于检查某个条件是否成立,它可以进行数值.字符和文件三个方面的测试. 实例演示: num1=100 num2=100 if test $[num1] -eq $[num2 ...

  5. 吴裕雄--天生自然ShellX学习笔记:Shell printf 命令

    printf 命令模仿 C 程序库(library)里的 printf() 程序. printf 由 POSIX 标准所定义,因此使用 printf 的脚本比使用 echo 移植性好. printf ...

  6. 吴裕雄--天生自然ShellX学习笔记:Shell echo命令

    Shell 的 echo 指令与 PHP 的 echo 指令类似,都是用于字符串的输出.命令格式: echo string 您可以使用echo实现更复杂的输出格式控制. 1.显示普通字符串: echo ...

  7. ELK学习笔记之使用curl命令操作elasticsearch

    0x00 _cat系列 _cat系列提供了一系列查询elasticsearch集群状态的接口.你可以通过执行curl -XGET localhost:9200/_cat 1. 获取所有_cat系列的操 ...

  8. CMake学习笔记四-CMake常用命令

    CMake常用命令 PROJECT PROJECT(projectname [CXX] [C] [Java]) 指定工程名称,并可指定工程支持的语言.支持语言列表可忽略,默认支持所有语言 SET ...

  9. RabbitMQ学习笔记四:RabbitMQ命令(附疑难问题解决)

    本来今天是想做RabbitMQ之优先级队列的,但是,在RabbitMQ Server创建queue时,增加优先级的最大值,头脑发热写了9999999,导致电脑内存直接飙到100%,只能重启电脑,并卸载 ...

随机推荐

  1. SiamRPN: High Performance Visual Tracking with Siamese Region Proposal Network

    High Performance Visual Tracking with Siamese Region Proposal Network 2018-11-26 18:32:02 Paper:http ...

  2. MiniUI treeGrid 树节点展开和不展开的性能差别很大

    参考API: http://miniui.com/docs/api/index.html#ui=datagrid http://miniui.com/docs/api/index.html#ui=tr ...

  3. Flutter Wrap 组件实现流布局

    Wrap 可以实现流布局,单行的 Wrap 跟 Row 表现几乎一致,单列的 Wrap 则跟 Row 表 现几乎一致.但 Row 与 Column 都是单行单列的,Wrap 则突破了这个限制,main ...

  4. Qt编写气体安全管理系统9-数据查询

    一.前言 数据查询模块在整个系统中难度最低,由于Qt对数据库操作的封装堪称完美,所以各种查询都是手到擒来,不费吹灰之力.Qt中内置了sqlite数据库,你可以在数据库插件目录sqldrivers发现q ...

  5. SignalR 传Model类型的参数

    目录 集线器方法 js调用 集线器方法 集线器写了一个方法是这样的 public void test(string name, Customer customer) 第一个参数是string类型的,第 ...

  6. jenkins升级完后一直显示升级中

    这个时候是已经升级成功了的,刷新界面,从新登录即可

  7. 使用mysql连接django时,需要的步骤以及错误解决办法

    django默认使用的sqlite3,更改为SQL时需要按照如下操作进行 1.在settings.py中的78行进行更改 DATABASES = { 'default': { 'ENGINE': 'd ...

  8. 十篇TED点击率最高演讲,带你重新认识大数据与人工智能

    我们通常过于专注于机器学习算法的实现,倾向于忽略这种技术本身的一些重要问题:如未来的应用和政治后果.在这篇文章中,我们从非常受欢迎的非营利组织TED上收集了一系列的视频(并非关注于选择什么语言或算法来 ...

  9. LeetCode 941. 有效的山脉数组(Valid Mountain Array)

    941. 有效的山脉数组 941. Valid Mountain Array 题目描述 给定一个整数数组 A,如果它是有效的山脉数组就返回 true,否则返回 false. 让我们回顾一下,如果 A ...

  10. 035 Android 广播(BroadCastReceiver)

    1.介绍 2.实现方法 3.注册广播 (1)静态广播 在AndroidManifest.xml文件中注册广播 <intent-filter>为过滤器 <receiver androi ...