首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >三、zookeeper 常用shell命令

三、zookeeper 常用shell命令

作者头像
IvanCodes
发布2025-09-28 11:10:51
发布2025-09-28 11:10:51
3100
代码可运行
举报
运行总次数:0
代码可运行

作者:IvanCodes 日期:2025年5月28日 专栏:Zookeeper教程

ZooKeeper Shell (zkCli.sh) 是与ZooKeeper服务器交互的核心工具。本教程将详细介绍常用命令,并重点解析ZooKeeper数据节点 (ZNode) 的特性与分类。

思维导图

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

一、连接 ZooKeeper 服务

使用 zkCli.sh 前,需连接到ZooKeeper服务器或集群。

命令:

代码语言:javascript
代码运行次数:0
运行
复制
zkCli.sh -server host1,host2,...

示例 (连接到您的 hadoop01,hadoop02,hadoop03 集群):

代码语言:javascript
代码运行次数:0
运行
复制
zkCli.sh -server hadoop01

成功连接后,提示符会显示连接状态。输入 quitclose 退出。

二、常用 Shell 命令详解

1. help 显示可用命令列表。

代码语言:javascript
代码运行次数:0
运行
复制
help

2. ls path [watch] 列出指定路径的直接子节点名称。

代码语言:javascript
代码运行次数:0
运行
复制
ls /
ls /zookeeper watch

3. ls -s path [watch]ls 类似,但除了列出子节点名称外,还会同时返回该路径节点自身的 stat 信息 (元数据)。

代码语言:javascript
代码运行次数:0
运行
复制
ls -s /
ls -s /zookeeper watch

对比 lsls -s: ls -s 在列出子节点的同时,省去了你再执行一次 stat /parent_path 的操作。

4. create [-s] [-e] path data [acl] 创建ZNode (不同类型如上文所述)。

代码语言:javascript
代码运行次数:0
运行
复制
create /my_persistent_node "Permanent Data"
create -e /my_ephemeral_node "Session Data"
create -s /my_sequential_node- "Sequential Data"
create -s -e /my_ephemeral_sequential_node- "Temp Seq Data"

5. get [-s] path [watch] 获取节点数据及元数据。

代码语言:javascript
代码运行次数:0
运行
复制
get -s /my_persistent_node

6. set path data [version] 更新节点数据。

代码语言:javascript
代码运行次数:0
运行
复制
set /my_persistent_node "Updated Data"
set /my_persistent_node "Versioned Update" 0 # 假设当前dataVersion为0

7. delete path [version] 删除无子节点的ZNode。

代码语言:javascript
代码运行次数:0
运行
复制
delete /my_ephemeral_node

8. deleteall path [ignoreErrors] (或 rmr path) 递归删除节点及其所有子节点。

代码语言:javascript
代码运行次数:0
运行
复制
# 较新版本
deleteall /my_persistent_node
# 较早版本
# rmr /my_persistent_node

9. stat path [watch] 仅获取节点元数据。

代码语言:javascript
代码运行次数:0
运行
复制
stat /

10. setAcl path acl 设置节点访问权限。

代码语言:javascript
代码运行次数:0
运行
复制
# 示例:将/secret节点设置为只有创建者有所有权限 (需要先进行认证)
# setAcl /secret auth:your_user:your_password_hashed:cdrwa (这是一个复杂场景,通常API操作)
setAcl /public_readable world:anyone:r # 任何人可读

11. getAcl path 获取节点访问权限。

代码语言:javascript
代码运行次数:0
运行
复制
getAcl /public_readable

12. history 列出当前会话中已执行的命令历史记录,最多显示最近10条。

代码语言:javascript
代码运行次数:0
运行
复制
history

13. redo cmdnum 重新执行历史记录中指定编号的命令。编号从 history 命令的输出中获取。

代码语言:javascript
代码运行次数:0
运行
复制
# 假设 history 输出的第3条命令是你想要的
redo 3

14. sync path 强制与Leader同步。

代码语言:javascript
代码运行次数:0
运行
复制
sync /

15. quit / close 退出客户端。

代码语言:javascript
代码运行次数:0
运行
复制
quit

练习题

  1. 连接到您的ZooKeeper集群,并使用 history 查看初始命令。
  2. 在根路径下创建一个名为 /app_root 的持久节点,数据为 “Application Root Node”。
  3. 使用 ls2 / 查看根路径子节点及根节点的stat信息,确认 /app_root 存在。
  4. /app_root 下创建一个名为 config- 的持久顺序节点,数据为 “Config v1”。记录下实际生成的节点名。
  5. 获取刚创建的持久顺序节点的数据和 dataVersion
  6. /app_root 下创建一个名为 live_instance 的临时节点,数据为 “Instance XYZ running”。
  7. 使用 stat /app_root/live_instance 查看其 ephemeralOwner 字段,理解其含义。
  8. 修改第4步创建的持久顺序节点的数据为 “Config v2”,并使用版本号进行乐观更新。
  9. 尝试使用 delete /app_root (不使用递归删除),观察结果。然后使用 deleteall (或 rmr) 正确删除 /app_root 及其所有子节点。
  10. 执行 history 命令,然后使用 redo 命令重新执行您创建 /app_root 的那条命令。

练习题答案

  1. 连接并查看history:
代码语言:javascript
代码运行次数:0
运行
复制
zkCli.sh -server hadoop01:2181,hadoop02:2181,hadoop03:2181
history

讲解: history 会显示连接命令本身或为空(如果这是第一个命令)。

  1. 创建 /app_root
代码语言:javascript
代码运行次数:0
运行
复制
create /app_root "Application Root Node"

讲解: 创建一个标准持久节点。

  1. 使用 ls2 / 查看:
代码语言:javascript
代码运行次数:0
运行
复制
ls2 /

讲解: ls2会列出 [zookeeper, app_root, ...] 等子节点,并紧随其后打印出 / 节点的stat信息(如 numChildren 会增加)。

  1. 创建持久顺序节点 config-
代码语言:javascript
代码运行次数:0
运行
复制
create -s /app_root/config- "Config v1"

讲解: ZooKeeper会自动生成类似 /app_root/config-0000000000 的节点。你需要记下这个实际名称。

  1. 获取持久顺序节点数据和版本: (假设上一步生成了 /app_root/config-0000000000)
代码语言:javascript
代码运行次数:0
运行
复制
get /app_root/config-0000000000

讲解: 记下 dataVersion 的值,初始应为0。

  1. 创建临时节点 live_instance
代码语言:javascript
代码运行次数:0
运行
复制
create -e /app_root/live_instance "Instance XYZ running"

讲解: -e 参数创建临时节点。

  1. 查看 live_instanceephemeralOwner
代码语言:javascript
代码运行次数:0
运行
复制
stat /app_root/live_instance

讲解: ephemeralOwner 字段会显示一个非零的会话ID,表示这个节点是临时的,并由该会话拥有。

  1. 修改持久顺序节点数据 (带版本): (假设 dataVersion 为0,节点名为 /app_root/config-0000000000)
代码语言:javascript
代码运行次数:0
运行
复制
set /app_root/config-0000000000 "Config v2" 0

讲解: 使用获取到的 dataVersion 进行条件更新。成功后,dataVersion 会变为1。

  1. 尝试删除及递归删除 /app_root
代码语言:javascript
代码运行次数:0
运行
复制
delete /app_root
# 这会失败,因为有子节点
# 使用 deleteall (或 rmr)
deleteall /app_root
# 或 rmr /app_root

讲解: 直接 delete 非空节点会失败。deleteallrmr 可以递归删除。

  1. 使用 historyredo
代码语言:javascript
代码运行次数:0
运行
复制
history
# 找到创建 /app_root "Application Root Node" 的命令编号,假设是 X
redo X

讲解: history 列出命令历史,redo 重新执行指定编号的命令。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2025-05-30,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 思维导图
  • 一、连接 ZooKeeper 服务
  • 二、常用 Shell 命令详解
  • 练习题
  • 练习题答案
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档