Zookeeper笔记之四字命令
Zookeeper支持一些命令用来获取服务的状态和相关信息,因为这些命令都是四个字母的,所以一般称为四字命令。
四字命令可以使用telnet或者nc向服务器提交,使用下面这个脚本可以当做是一个简易的客户端,它接收四字命令,发送到指定服务器,并将执行结果显示在控制台上,同时为了体验好一些,还提供了prompt来将用户输入的命令和命令的执行结果做区分:
#! /bin/bash # [$1] server host
# [$2] server port
show_prompt(){
if [ $# -eq 2 ]; then
echo -n "$1:$2> "
else
echo -n "> "
fi
} show_help(){
echo 'Usage: '
echo ' four-letter-word-cli [server-host] [server-port]'
echo ' server-host and server-port default is localhost:2181'
} # [$1] server host, default localhost
# [$2] server port, default 2181
four_letter_word_client(){ # 帮助信息
if [ "$1" == "-h" ]; then
show_help
return 0
fi # 检查参数,若未传递则使用默认值
server_host=${1-"localhost"}
server_port=${2-2181} # 循环接收命令并执行
show_prompt $server_host $server_port
while read command
do
# 支持exit退出,兼容各种大小写情况
if [ `echo "foo-$command" | tr A-Z a-z` == "foo-exit" ]; then
echo "bye."
return 0
fi echo $command | nc $server_host $server_port
show_prompt $server_host $server_port
done
} # main
four_letter_word_client $@
效果如下:
conf
输出服务相关的配置信息。
localhost:2181> conf
clientPort=2181
dataDir=/tmp/zookeeper/version-2
dataLogDir=/tmp/zookeeper/version-2
tickTime=3000
maxClientCnxns=0
minSessionTimeout=6000
maxSessionTimeout=60000
serverId=0
clientPort:服务监听在哪个端口上了
dataDir:数据文件的目录
dataLogDir:日志文件的目录,zk会将所有操作以类似于binlog的形式记录下来
tickTime:
maxClientCnxns:最大连接数
minSessionTimeout:最小session超时时间
maxSessionTimeout:最大session超时时间
serverId:
cons
列出连接到服务器的客户端的连接信息。
localhost:2181> cons
/127.0.0.1:48482[1](queued=0,recved=1,sent=1,sid=0x163206280b2000c,lop=SESS,est=1527335699876,to=30000,lcxid=0x0,lzxid=0x68,lresp=1527335699898,llat=6,minlat=0,avglat=6,maxlat=6)
/127.0.0.1:48486[0](queued=0,recved=1,sent=0)
/127.0.0.1 ip地址
:48482 端口
[1]( 连接编号
queued=0, 所在队列
recved=1, 接收包数量
sent=1, 发送包数量
sid=0x163206280b2000c, 会话id
lop=SESS, 最后一次进行的操作
est=1527335699876, 连接时间戳
to=30000, 超时时间,timeout
lcxid=0x0, 最后id(未确认具体id)
lzxid=0x68, 最后id(状态变更id)
lresp=1527335699898, 最后响应时间戳
llat=6, 最后/最新延时
minlat=0, 最小延时
avglat=6, 平均延时
maxlat=6) 最大延时
dump
列出未经处理的会话和临时节点
localhost:2181> dump
SessionTracker dump:
Session Sets (3):
0 expire at Sat May 26 19:56:12 CST 2018:
0 expire at Sat May 26 19:56:21 CST 2018:
1 expire at Sat May 26 19:56:30 CST 2018:
0x163206280b2000c
ephemeral nodes dump:
Sessions with Ephemerals (0):
envi
服务环境相关信息
Environment:
zookeeper.version=3.4.11-37e277162d567b55a07d1755f0b31c32e93c01a0, built on 11/01/2017 18:06 GMT
host.name=localhost
java.version=1.8.0_161
java.vendor=Oracle Corporation
java.home=/opt/jdk/jdk1.8.0_161/jre
java.class.path=/opt/zookeeper/zookeeper-3.4.11/bin/../build/classes:/opt/zookeeper/zookeeper-3.4.11/bin/../build/lib/*.jar:/opt/zookeeper/zookeeper-3.4.11/bin/../lib/slf4j-log4j12-1.6.1.jar:/opt/zookeeper/zookeeper-3.4.11/bin/../lib/slf4j-api-1.6.1.jar:/opt/zookeeper/zookeeper-3.4.11/bin/../lib/netty-3.10.5.Final.jar:/opt/zookeeper/zookeeper-3.4.11/bin/../lib/log4j-1.2.16.jar:/opt/zookeeper/zookeeper-3.4.11/bin/../lib/jline-0.9.94.jar:/opt/zookeeper/zookeeper-3.4.11/bin/../lib/audience-annotations-0.5.0.jar:/opt/zookeeper/zookeeper-3.4.11/bin/../zookeeper-3.4.11.jar:/opt/zookeeper/zookeeper-3.4.11/bin/../src/java/lib/*.jar:/opt/zookeeper/zookeeper-3.4.11/bin/../conf:.:/opt/jdk/jdk1.8.0_161/lib:/lib:
java.library.path=/usr/java/packages/lib/amd64:/usr/lib64:/lib64:/lib:/usr/lib
java.io.tmpdir=/tmp
java.compiler=<NA>
os.name=Linux
os.arch=amd64
os.version=3.10.0-514.26.2.el7.x86_64
user.name=root
user.home=/root
user.dir=/opt/zookeeper/zookeeper-3.4.11/bin
上面列出的主要是服务器用到的一些环境变量即其值。
reqs
列出未经处理的请求
ruok
测试服务器是否处于正确状态,如果是的话返回“imok”,否则的话没有任何回应。
stat
关于性能和客户端的连接信息
imoklocalhost:2181> stat
Zookeeper version: 3.4.10-39d3a4f269333c922ed3db283be479f9deacaa0f, built on 03/23/2017 10:13 GMT
Clients:
/127.0.0.1:49202[0](queued=0,recved=1,sent=0)
/127.0.0.1:48482[1](queued=0,recved=62,sent=62) Latency min/avg/max: 0/0/63
Received: 468342
Sent: 468348
Connections: 2
Outstanding: 0
Zxid: 0x68
Mode: standalone
Node count: 28
wchs
列出服务器的watch信息
wchc
通过session列出服务器的watch信息,输出是一个与watch相关的会话列表
wchp
通过路径列出服务器watch信息,输入与session相关的路径
.
Zookeeper笔记之四字命令的更多相关文章
- zookeeper之 zkServer.sh命令、zkCli.sh命令、四字命令
一.zkServer.sh 1.查看 zkServer.sh 帮助信息[root@bigdata05 bin]# ./zkServer.sh helpZooKeeper JMX enabled by ...
- Zookeeper四字命令
ZooKeeper 支持某些特定的四字命令(The Four Letter Words)与其进行交互.它们大多是查询命令,用来获取 ZooKeeper 服务的当前状态及相关信息.用户在客户端可以通过 ...
- 【转】zookeeper之 zkServer.sh命令、zkCli.sh命令、四字命令
[FROM]https://www.cnblogs.com/andy6/p/7674028.html 一.zkServer.sh 1.查看 zkServer.sh 帮助信息 [root@bigdata ...
- 搭建zookeeper单机版以及简单命令的使用
1:创建目录 #数据目录dataDir=/opt/hadoop/zookeeper-3.3.5-cdh3u5/data#日志目录dataLogDir=/opt/hadoop/zookeeper-3.3 ...
- 五:ZooKeeper的集群命令客户端的链接和命令操作的使用
一:zookeeper客户端链接[1]进入zookeeper的安装目录的bin目录下 # cd /opt/zookeeper/bin[2]敲击链接客户端的命令(zkCli.sh) ...
- zookeeper Cli的常用命令
zookeeper Cli的常用命令 服务管理 启动ZK服务: zkServer.sh start 查看ZK状态: zkServer.sh status 停止ZK服务: zkServer.sh sto ...
- zookeeper命令行(zkCli.sh&zkServer.sh)使用及四字命令
zookeeper提供了很多方便的功能,方便我们查看服务器的状态,增加,修改,删除数据(入口是zkServer.sh和zkCli.sh). 还提供了一系列四字命令,方便我们跟服务器进行各种交互,来确认 ...
- zookeeper 四字命令的使用
Linux中的命令NetCat有“瑞士军刀”的美誉.我们可以通过nc命令查看Zookeeper的一行属性数据.在Zookeeper中有很多四字命令,汇总如下: 序号 使用命令 输出说明 1 echo ...
- zookeeper 四字命令
zookeeper四字命令 ZooKeeper3.4.6支持某些特定的四字命令字母与其的交互.它们大多是查询命令,用来获取 ZooKeeper 服务的当前状态及相关信息.用户在客户端可以通过 te ...
随机推荐
- 互联网寒冬,Python 程序员如何准备面试
虽说年年都在喊互联网寒冬,最难就业季,但是今年确实有点不一样,年前年后一波又一波互联网公司宣布『人员调整,结构优化』, 这是往年没发生过的. 是不是面试机会就少了很多呢?不是的. 搜索招聘网站我们可以 ...
- PAT甲题题解-1006. Sign In and Sign Out (25)-找最小最大
判断哪个人最早到,哪个人最晚走水,就是找最大值最小值 #include <iostream> #include <cstdio> #include <algorithm& ...
- D. Vasya and Arrays
链接 [http://codeforces.com/contest/1036/problem/D] 题意 给你两个数组长度分别为n,m; 有这么一种操作,用某个数组的某个子区间元素之和代替这个子区间, ...
- tomcat运行JSP时产生的错误:”javax.servlet.servletexception: java.lang.nosuchmethoderror”
这个错误其实是多次重复编译JAVA文件导致的,需要clean操作,简单的来说就是删除tomcat下work文件夹中工作空间,也可以理解为自己的虚拟路径,比如我运行的jsp的路径:localhost:8 ...
- Test Cases
对于mode1 1 路径下一个空文件夹 结果:生成一个空的txt 2路径下一个文件夹内包含一个txt内容为abd(最基本的一个单词) 3路径下一个空文件夹一个txt,txt内容为以不同符号 ...
- (NOI2014)(bzoj3669)魔法森林
LCT裸题,不会的可以来这里看看. 步入正题,现将边按a排序,依次加入每一条边,同时维护路径上的最小生成树上的最大边权,如果两点不连通,就直接连通. 如果两点已经连通,就将该边与路径上较小的一条比较, ...
- 洛谷P3703 [SDOI2017]树点涂色(LCT,dfn序,线段树,倍增LCA)
洛谷题目传送门 闲话 这是所有LCT题目中的一个异类. 之所以认为是LCT题目,是因为本题思路的瓶颈就在于如何去维护同颜色的点的集合. 只不过做着做着,感觉后来的思路(dfn序,线段树,LCA)似乎要 ...
- 【转】四款经典3.7v锂电池充电电路图详解
3.7v锂电池充电电路图(一) 1.锂电池的充电: 根据锂电池的结构特性,最高充电终止电压应为4.2V,不能过充,否则会因正极的锂离子拿走太多,而使电池报废.其充放电要求较高,可采用专用的恒流.恒压充 ...
- 【转】crc16几种标准校验算法及c语言代码
一.CRC16校验码的使用 现选择最常用的CRC-16校验,说明它的使用方法. 根据Modbus协议,常规485通讯的信息发送形式如下: 地址 功能码 数据信息 校验码 1byte 1byte nby ...
- bzoj 4328 始祖鸟
4328: JSOI2012 始祖鸟 Time Limit: 10 Sec Memory Limit: 256 MBSec Special JudgeSubmit: 76 Solved: 52[ ...