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 ...
随机推荐
- 手机定位室内gps没信号
手机定位一般分3种,gps,手机信号基站,上网地点,其中gps信号一般只有户外有,所以在室外的时候只开启定位和gps就可以定位了,但是在室内没有gps的情况,就需要开网络定位了.
- Python多进程-进程间数据的共享
不同的进程不能同时修改一份数据,但是不同的进程能对一份数据进行修改 可通过Manager来实现进程间的数据共享 # -*- coding:utf-8 -*- __author__ = "Mu ...
- 类型:JQuery;问题:ajax调用ashx文件;结果:ashx文件怎么获取$.ajax()方法发送的json数据
ashx文件怎么获取$.ajax()方法发送的json数据 作者:careful 和ajax相关 新浪微博QQ空间QQ微博百度搜藏腾讯朋友QQ收藏百度空间人人网开心网0 $.ajax({ t ...
- DAY10-python并发编程之携程
一.引子 本节的主题是基于单线程来实现并发,即只用一个主线程(很明显可利用的cpu只有一个)情况下实现并发,为此我们需要先回顾下并发的本质:切换+保存状态 cpu正在运行一个任务,会在两种情况下切走去 ...
- 用原生JS和html5进行视频截图并保存到本地
<!doctype html> <html> <head> <meta charset="utf-8"> <title> ...
- CodeForces 1109C. Sasha and a Patient Friend
题目简述:维护以下三种操作 1. "1 t s":在时刻$t$插入命令$s$.保证任意操作后,任意时刻至多只有一个命令. 2. "2 t":删除时刻$t$的命令 ...
- Ros学习service——小海龟
rosservice 服务(services)是节点之间通讯的另一种方式.服务允许节点发送请求(request) 并获得一个响应(response) rosservice list 输出可用服务的信息 ...
- 电子模块 001 --- 遥杆 JoyStick
电子模块 001 - 遥杆 JoyStick - Ongoing - 2016年8月31日 星期三 遥杆 JoyStick 模块 今天介绍:JoyStick 电子模块. 模块名称: 双轴按键摇杆 PS ...
- ZXing开发详解
博客转载自:https://blog.csdn.net/skillcollege/article/details/38852183 什么是Z*? 在Android平台做过二维码相关模块的肯定都熟知ZX ...
- js/jq基础(日常整理记录)-2-一个简单的js方法实现集合的非引用拷贝
一.一个简单的js方法实现集合拷贝 做web项目的时候,少不了和js中的数组,集合等对象接触,那么你肯定会发现,在js中存在一个怪异的现象就是数组和集合的拷贝都是地址复制,并不是简单的数据的拷贝. 举 ...