一篇文章教你安装Zookeeper,并且教会你如何使用命令操作zookeeper

2021-08-10 10:27:37 浏览数 (1)

目录

  • Zookeeper简介
  • 安装
  • 使用
    • Zookeeper客户端常用命令
      • ls
      • create
      • get
      • set
      • delete

Zookeeper简介

zookeeper分布式管理软件。常用它做注册中心(依赖zookeeper的发布/订阅功能)、配置文件中心、分布式锁配置、集群管理等。 zookeeper一共就有两个版本。主要使用的是java语言写的。

安装

网上下载zookeeper 安装包

打开虚拟机, 上传这个安装包

1 上传压缩文件 上传到 /usr/local/tmp中

2 解压 tar zxf apache-zookeeper-3.5.5-bin.tar.gz cp -r apache-zookeeper-3.5.5-bin …/zookeeper

3 新建data目录 zookeeper 是一个软件,里面要存东西,所以我们要创建一个文件夹,里面就是存我们要保存的东西

进入到zookeeper中 cd /usr/local/zookeeper mkdir data

4 修改配置文件 我们自己创建的data文件夹,zookeeper软件是咋知道的,所以需要配置,和maven仓库的配置一样 进入conf中 cd conf cp zoo_sample.cfg zoo.cfg vim zoo.cfg 修改dataDir为data文件夹路径

5 启动zookeeper 进入bin文件夹 cd /usr/local/zookeeper/bin ./zkServer.sh start

通过status查看启动状态。稍微有个等待时间 ./zkServer.sh status

使用

我们可以把zookeeper当做MySQL,我们的MySQL也有cmd里面可以操作,有一个命令的客户端,所以zookeeper也有的

Zookeeper客户端常用命令

进入到./zkCli.sh命令行工具后,可以使用下面常用命令 注意: MySql数据存储数据是按照二维表的结构存储的,我们查找数据也是按照二维表的方式去查找。但是Zookeeper的底层使用的节点的方式,树结构。比如,一个苹果树,上面結满了苹果,每个苹果都有自己的绝对路径,从苹果树的根开始查找。也就说 我们在Zookeeper中存储的数据需要提供数据存储的绝对路径,查询数据时也需要提供数据的绝对路径。

以下就是zookeeper的客户端

ls

ls [-s] [-R] /path -s 详细信息,替代老版的ls2 -R 当前目录和子目录中内容都罗列出来 例如:ls -R / 显示根目录下所有内容

以上是刚安装zookeeper软件,里面自带的目录 自带一个zookeeper的目录

create

create /path [data] [data] 包含内容 创建指定路径信息 例如:create /demo 创建/demo (在根路径下创建一个demo的文件夹)

也就是用以上的命令,创建了一个目录

create /node 第一次创建可以,第二次创建同一个名字的时候,就会说已经有这个节点,不让创建

create -s /node 第一次创建的时候,会自动给你一个编号,再创建同名字的,会创建,但是每一个编号不一样

记住:

一个节点里面只能创建一个URL地址

get

get [-s] /path [-s] 详细信息 查看指定路径下内容。 例如: get -s /demo

代码语言:javascript复制
null:存放的数据
cZxid:创建时zxid(znode每次改变时递增的事务id)
ctime:创建时间戳
mZxid:最近一次更近的zxid
mtime:最近一次更新的时间戳
pZxid:子节点的zxid
cversion:子节点更新次数
dataversion:节点数据更新次数
aclVersion:节点ACL(授权信息)的更新次数
ephemeralOwner:如果该节点为ephemeral节点(临时,生命周期与session一样), ephemeralOwner值表示与该节点绑定的session id. 如果该节点不是ephemeral节点, ephemeralOwner值为0.
dataLength:节点数据字节数
numChildren:子节点数量

set

set /path data 设置节点内容

也就是利用这个命令,往目录里面保存数据

delete

delete /path 删除节点

0 人点赞