Zookeeper基础使用
部署和运行
脚本
ZooKeeper的bin
目录下的脚本见下表
脚本 | 说明 |
---|---|
zkCleanup | 清理ZooKeeper历史数据,包括事务日志文件和快照数据文件 |
zkCli | ZooKeeper的一个简易客户端 |
zkEnv | 设置ZooKeeper的环境变量 |
zkServer | ZooKeeper服务器的启动、停止和重启 |
启动服务
常见的启动方式有两种:
Java命令行, 在ZooKeeper目录下执行如下命令
java -cp zookeeper-3.4.6.jar:lib
使用自带脚本启动,在ZooKeeper目录下执行如下命令:
./bin/zkServer.sh
停止服务
可以使用zkServer脚本的stop命令来停止服务。
sh bin/zkServer.sh stop
基本指令
客户端连接
Zookeeper自带的脚本里有个zkCli,是ZooKeeper的一个简易客户端, 使用方式:
zkCli.sh [-server ip:port]
运行如下指令启动客户端可以连接到默认服务器localhost:2181
bin/zkCli.sh
看到下面输表明连接正常:
Connecting to localhost:2181
2019-03-27 17:05:34,602 [myid:] - INFO [main:Environment@100] - Client environment:zookeeper.version=3.4.6-1569965, built on 02/20/2014 09:09 GMT
2019-03-27 17:05:34,605 [myid:] - INFO [main:Environment@100] - Client environment:host.name=WANJP3
2019-03-27 17:05:34,605 [myid:] - INFO [main:Environment@100] - Client environment:java.version=1.8.0_20
2019-03-27 17:05:34,607 [myid:] - INFO [main:Environment@100] - Client environment:java.vendor=Oracle Corporation
2019-03-27 17:05:34,608 [myid:] - INFO [main:Environment@100] - Client environment:java.home=C:\Program Files\Java\jre1.8.0_20
2019-03-27 17:05:34,608 [myid:] - INFO [main:Environment@100] - Client environment:java.class.path=D:\zookeeper-3.4.6\bin\..\build\classes;D:\zookeeper-3.4.6\bin\..\build\lib\*;D:\zookeeper-3.4.6\bin\..\zookeeper-3.4.6.jar;D:\zookeeper-3.4.6\bin\..\lib\jline-0.9.94.jar;D:\zookeeper-3.4.6\bin\..\lib\log4j-1.2.16.jar;D:\zookeeper-3.4.6\bin\..\lib\netty-3.7.0.Final.jar;D:\zookeeper-3.4.6\bin\..\lib\slf4j-api-1.6.1.jar;D:\zookeeper-3.4.6\bin\..\lib\slf4j-log4j12-1.6.1.jar;D:\zookeeper-3.4.6\bin\..\conf
2019-03-27 17:05:34,609 [myid:] - INFO [main:Environment@100] - Client environment:java.library.path=C:\ProgramData\Oracle\Java\javapath;C:\WINDOWS\Sun\Java\bin;C:\WINDOWS\system32;C:\WINDOWS;D:\Oracle\product\11.2.0\client_2\bin;D:\Oracle\Oracle64;D:\Oracle;C:\ProgramData\Oracle\Java\javapath;C:\Program Files (x86)\Intel\iCLS Client\;C:\Program Files\Intel\iCLS Client\;C:\Windows\system32;C:\Windows;C:\Windows\System32\Wbem;C:\Windows\System32\WindowsPowerShell\v1.0\;C:\Program Files (x86)\Intel\Intel(R) Management Engine Components\DAL;C:\Program Files\Intel\Intel(R) Management Engine Components\DAL;C:\Program Files (x86)\Intel\Intel(R) Management Engine Components\IPT;C:\Program Files\Intel\Intel(R) Management Engine Components\IPT;C:\Program Files (x86)\NVIDIA Corporation\PhysX\Common;D:\node\;D:\VSCode\bin;d:\eclipse\;C:\WINDOWS\system32;C:\WINDOWS;C:\WINDOWS\System32\Wbem;C:\WINDOWS\System32\WindowsPowerShell\v1.0\;C:\WINDOWS\System32\OpenSSH\;C:\Program Files\TortoiseSVN\bin;D:\gradle-4.10\bin;D:\gradle-4.10\;D:\node\node_global_modules\;C:\Program Files\Git\bin\;D:\apache-maven-3.5.4\bin;C:\Program Files\NVIDIA Corporation\NVIDIA NvDLISR;;%SystemRoot%\system32;%SystemRoot%;%SystemRoot%\System32\Wbem;%SYSTEMROOT%\System32\WindowsPowerShell\v1.0\;%SYSTEMROOT%\System32\OpenSSH\;C:\Users\nan\AppData\Local\Microsoft\WindowsApps;C:\Users\nan\AppData\Roaming\npm;;.
2019-03-27 17:05:34,610 [myid:] - INFO [main:Environment@100] - Client environment:java.io.tmpdir=C:\Users\nan\AppData\Local\Temp\
2019-03-27 17:05:34,610 [myid:] - INFO [main:Environment@100] - Client environment:java.compiler=<NA>
2019-03-27 17:05:34,611 [myid:] - INFO [main:Environment@100] - Client environment:os.name=Windows 8.1
2019-03-27 17:05:34,611 [myid:] - INFO [main:Environment@100] - Client environment:os.arch=amd64
2019-03-27 17:05:34,611 [myid:] - INFO [main:Environment@100] - Client environment:os.version=6.3
2019-03-27 17:05:34,612 [myid:] - INFO [main:Environment@100] - Client environment:user.name=nan
2019-03-27 17:05:34,612 [myid:] - INFO [main:Environment@100] - Client environment:user.home=C:\Users\nan
2019-03-27 17:05:34,621 [myid:] - INFO [main:Environment@100] - Client environment:user.dir=D:\zookeeper-3.4.6
2019-03-27 17:05:34,623 [myid:] - INFO [main:ZooKeeper@438] - Initiating client connection, connectString=localhost:2181 sessionTimeout=30000 watcher=org.apache.zookeeper.ZooKeeperMain$MyWatcher@277050dc
Welcome to ZooKeeper!
2019-03-27 17:05:34,714 [myid:] - INFO [main-SendThread(127.0.0.1:2181):ClientCnxn$SendThread@975] - Opening socket connection to server 127.0.0.1/127.0.0.1:2181. Will not attempt to authenticate using SASL (unknown error)
2019-03-27 17:05:34,716 [myid:] - INFO [main-SendThread(127.0.0.1:2181):ClientCnxn$SendThread@852] - Socket connection established
to 127.0.0.1/127.0.0.1:2181, initiating session
JLine support is enabled
[zk: localhost:2181(CONNECTING) 0] 2019-03-27 17:05:34,856 [myid:] - INFO [main-SendThread(127.0.0.1:2181):ClientCnxn$SendThread@1235] - Session establishment complete on server 127.0.0.1/127.0.0.1:2181, sessionid = 0x169be6525760000, negotiated timeout = 30000
WATCHER::
WatchedEvent state:SyncConnected type:None path:null
ls
[zk: localhost:2181(CONNECTED) 1]
创建
通过zkCli连接服务器后,使用```create``可以创建一个ZooKeeper节点,使用方式:
create [-s] [-e] path data acl
-s
顺序节点, -e
临时节点,如果补添加创建的就是持久节点
acl
是权限控制,缺省情况下,不做任何权限控制
读取
读取指令有两种,ls
列出指定节点下的子节点, get
获取指定节点的数据内容和属性信息,两个指令的使用方式如下:
ls path [wacth]
get path [watch]
[zk: localhost:2181(CONNECTED) 21] create /test 123
Created /test
[zk: localhost:2181(CONNECTED) 22] ls /test
[]
[zk: localhost:2181(CONNECTED) 23] get /test
123
cZxid = 0x28
ctime = Wed Mar 27 17:42:45 CST 2019
mZxid = 0x28
mtime = Wed Mar 27 17:42:45 CST 2019
pZxid = 0x28
cversion = 0
dataVersion = 0
aclVersion = 0
ephemeralOwner = 0x0
dataLength = 3
numChildren = 0
cZxid
创建该节点的事务ID,mZxid
最后一次更新该节点的事务ID
更新
set
命令用于更新指定节点的数据内容,使用方式如下:
set path data [version]
[zk: localhost:2181(CONNECTED) 24] set /test 111
cZxid = 0x28
ctime = Wed Mar 27 17:42:45 CST 2019
mZxid = 0x29
mtime = Wed Mar 27 17:49:59 CST 2019
pZxid = 0x28
cversion = 0
dataVersion = 1
aclVersion = 0
ephemeralOwner = 0x0
dataLength = 3
numChildren = 0
[zk: localhost:2181(CONNECTED) 25] get /test
111
cZxid = 0x28
ctime = Wed Mar 27 17:42:45 CST 2019
mZxid = 0x29
mtime = Wed Mar 27 17:49:59 CST 2019
pZxid = 0x28
cversion = 0
dataVersion = 1
aclVersion = 0
ephemeralOwner = 0x0
dataLength = 3
numChildren = 0
[zk: localhost:2181(CONNECTED) 26]
执行更新命令后,节点/test
的数据已经变成111,````cZxid没有变化,
mZxid变成了0x29,
dataVersion```从0变成了1。
删除
delete
命令用于删除指定节点,使用方式如下:
delete path [version]
删除节点时,该节点不能有子节点。如下:
[zk: localhost:2181(CONNECTED) 27] create /test/test-1 101
Created /test/test-1
[zk: localhost:2181(CONNECTED) 28] ls /test
[test-1]
[zk: localhost:2181(CONNECTED) 29] delete /test
Node not empty: /test
[zk: localhost:2181(CONNECTED) 30] delete /test/test-1
[zk: localhost:2181(CONNECTED) 31] ls
[zk: localhost:2181(CONNECTED) 32] ls /test
[]
[zk: localhost:2181(CONNECTED) 33] delete /test
[zk: localhost:2181(CONNECTED) 34] ls /test
Node does not exist: /test
Zookeeper基础使用的更多相关文章
- zookeeper_02:zookeeper基础
ZooKeeper基础概述 ZooKeeper维护一个小型的数据节点,这些节点被称为znode,采用类似于文件系统的层级树状结构进行管理. 针对一个znode,没有数据常常表达了重要的信息.比如,在主 ...
- Hadoop系列-zookeeper基础
目前是刚刚初学完zookeeper,这篇文章主要是简单的对一些基本的概念进行梳理强化. zookeeper基础概念的理解 有时候计算机领域很多名词都是从一长串英文提取首字母缩写而来,但很不幸zooke ...
- Zookeeper 基础、工作流、ZAP协议
ZooKeeper 基础 在深入了解ZooKeeper的运作之前,让我们来看看ZooKeeper的基本概念.[1] 我们将在本章中讨论以下主题:1.Architecture(架构)2.Hierarch ...
- Zookeeper系列一:Zookeeper基础命令操作
有些事不是努力就可以改变的,五十块的人民币设计的再好看,也没有一百块的招人喜欢. 前言 由于公司年底要更换办公地点,所以最近投了一下简历,发现面试官现在很喜欢问dubbo.zookeeper和高并发等 ...
- Zookeeper基础教程(六):.net core使用Zookeeper
Demo代码已提交到gitee,感兴趣的更有可以直接克隆使用,地址:https://gitee.com/shanfeng1000/dotnetcore-demo/tree/master/Zookeep ...
- Zookeeper基础教程(五):C#实现Zookeeper分布式锁
分布式锁 互联网初期,我们系统一般都是单点部署,也就是在一台服务器完成系统的部署,后期随着用户量的增加,服务器的压力也越来越大,响应速度越来越慢,甚至出现服务器崩溃的情况. 为解决服务器压力太大,响应 ...
- 第一章 zookeeper基础概念
1.ZooKeeper是什么 ZooKeeper为分布式应用提供了高效且可靠的分布式协调服务,提供了统一命名服务. 配置管理和分布式锁等分布式的基础服务.在解决分布式数据一致性方面, ZooKeepe ...
- ZooKeeper基础
======================================ZooKeeper 背景======================================ZooKeeper 是一 ...
- Zookeeper(一) zookeeper基础使用
一.Zookeeper是什么 (安装的是3.4.7) ZooKeeper 是一个分布式的,开放源码的分布式应用程序协调服务,是 Google 的 Chubby 一个开源的实现.它提供了简单原始的功能, ...
- Zookeeper基础命令操作
转载链接:https://blog.csdn.net/dandandeshangni/article/details/80558383 安装参考链接https://blog.csdn.net/qiun ...
随机推荐
- TP-Link WR703N OpenWRT固件修改WAN LAN排序
有一种方法就是macvlan了.添加到rc.local文件中,具体不再阐述. 此方法只适合编译固件的情况下调整WAN/LAN顺序. wr703n等(包含其他未列出的单网口路由,AP),修改WAN LA ...
- JavaScript语言基础-对象与数组
- java.util.Date、java.sql.Date、java.sql.Time、java.sql.Timestamp区别和总结
在web开发中,避免不了对日期的操作,就几种常见的日期操作做个总结(部分参考网络,在此表示感谢): java.util.Date.java.sql.Date.java.sql.Time.java.sq ...
- centos7虚拟机桥接上网(DHCP)
centos设置成自动获取ip地址方式(DHCP) 1.打开终端查看网卡信息 #ifconfigifcfg-enp0s3lovirbro 2.编辑文件#vim /etc/sysconfig/netwo ...
- [luogu3385]dfs_spfa判负环模板
解题关键:模板保存. 判负环不需要memset dis数组,因为已经更新过得d数组一定小于0,如果当前点可以更新d,说明d更小,有可能继续扩大负环,所以继续更新:如果比d[v]大,则不可能继续更新负环 ...
- schedule与scheduleAtFixedRate比较
schedule与scheduleAtFixedRate: 不延时: schedule(TimerTask, Date runDate, long period)方法任务不延时----Date类型 i ...
- php单引号双引号的区别
单引号里面的内容是直接被当做一个字符串,用双引号定义的字符串的内容最只要的特征就是会被解析.
- (转)typedef和#define的用法与区别
typedef和#define的用法与区别 一.typedef的用法 在C/C++语言中,typedef常用来定义一个标识符及关键字的别名,它是语言编译过程的一部分,但它并不实际分配内存空间,实例像: ...
- Linux minicom命令
一.简介 minicom是Linux下的超级终端,与Windows下的超级终端功能相似,可以通过串口控制外部的硬件设备,可以用于管理和控制嵌入式设备 二.安装 1)yum安装 yum install ...
- 一个小错误,在for循环中,每次repaint()的时候,记得先把frame涂成白色的。等于擦掉原来的痕迹·。
import java.awt.*; import java.awt.event.*; import javax.swing.*; public class Animate { int x=1; in ...