博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
ZooKeeper监控工具(六)
阅读量:6931 次
发布时间:2019-06-27

本文共 2254 字,大约阅读时间需要 7 分钟。

之前说了那么多配置信息,具体做的怎么样,还需要真正的获取ZooKeeper的运行时信息才行。这里介绍ZooKeeper的监控。

img_046fccbdb13796fd373f5841f2f41491.png
与文无关

有如下方式:

  • 使用内置的四字命令来获取健康状态信息
  • 使用JMX查看运行状态
  • 使用Exhibitor
  • 使用Sass

四字命令

最简单的监控方式就是使用ZooKeeper的四字命令,你可以直接通过telnet或者nc命令查看状态。

img_80dc6bec0bdbb1e89452346155bb02df.png
四字命令
img_4d337d6ab9ce3fa58a83ead6f99dbc4e.png
四字命令
img_93c0c44f2b0783a76ad107f109fe047b.png
四字命令

常用的四字命令如下:

  • conf: 打印ZooKeeper的配置信息
  • cons: 列出所有的客户端会话链接
  • crst: 重置所有的客户端连接
  • dump: 打印集群的所有会话信息,包括ID,以及临时节点等信息。用在Leader节点上才有效果。
  • envi: 列出所有的环境参数
  • ruok: "谐音为Are you ok"。检查当前服务器是否正在运行。
  • stat: 获取ZooKeeper服务器运行时的状态信息,包括版本,运行时角色,集群节点个数等信息。
  • srst: 重置服务器统计信息
  • srvr: 和stat输出信息一样,只不过少了客户端连接信息。
  • wchs: 输出当前服务器上管理的Watcher概要信息
  • wchc: 输出当前服务器上管理的Watcher的详细信息,以session为单位进行归组
  • wchp: 和wchc非常相似,但是以节点路径进行归组
  • mntr: 输出比stat更为详细的服务器统计信息

JMX

JMX是用来远程监控Java应用的框架,这个也可以用来监控其他的Java应用。JMX使用起来也很简单。

在运行Java的jar的时候:

//不需要用户密码的-Dcom.sun.management.jmxremote.port=5000  -Dcom.sun.management.jmxremote.authenticate=true -Dcom.sun.management.jmxremote.ssl=false // 使用需要用户密码登录的-Dcom.sun.management.jmxremote.port=5000  -Dcom.sun.management.jmxremote.authenticate=true -Dcom.sun.management.jmxremote.ssl=false -Dcom.sun.management.jmxremote.access.file=jmxremote.access-Dcom.sun.management.jmxremote.password.file=jmxremote.password    cat jmxremote.accessmonitorRole   readonlycontrolRole   readwrite cat jmxremote.passwordmonitorRole mypasswordcontrolRole mypassword

接下来,我们可以使用jConsole或者VisualVM进行监控。

默认情况下,ZooKeeper允许本地进行监控。

img_b24b68d27847f6acff52a95d31c012e2.png
jconsole图

如果想要远程监控,可以修改zkServer.sh文件中的shell脚本

img_bf989347f32bf2265e65419c7a71a3c1.png
JMX参数图

修改方式为我们刚才看到的加上

-Dcom.sun.management.jmxremote.access.file=jmxremote.access-Dcom.sun.management.jmxremote.password.file=jmxremote.password

Exhibitor

Exhibitor是一个ZooKeeper的管理工具,由Netfix公司开发,在ZooKeeper监控,备份恢复,清洁,在可视化上提供了不小的帮助。

  1. 首先我们下载exhibitor的pom文件
mkdir buildcd build wget -c https://raw.github.com/Netflix/exhibitor/master/exhibitor-standalone/src/main/resources/buildscripts/standalone/maven/pom.xml
  1. 打包编译jar包
//这个打包的时间真心长mvn clean package// 测试是否正确打包,这个exhibitor根据你自己打包出来的文件名进行测试java -jar target/exhibitor-1.6.0.jar --help
  1. 运行
java -jar exhibitor-1.6.0.jar -c file
  1. 在浏览器中输入exhibitor的地址

    http://服务器地址:8080/exhibitor/v1/ui/index.html

  2. 配置Exhibitor

    img_b6a127383f08f43da40a8411393eb258.png
    Exhibitor面板
  1. 更多Exhitor的详细信息,参考github的wiki

云服务商

当然也有一些云服务商提供ZooKeeper的监控服务,一般都是收费的。

国外的有:server density. 网站:

最后

在看ZooKeeper监控的时候,发现ZooKeeper的监控工具都很老了,大部分都是几年前的了,ZooKeeper这是要被淘汰了吗...,好用的软件应该都有很好用的工具才对。不过既然当初它那么流行,还是有值得研究的地方...

参考

  • 《从Paxos到ZooKeeper-分布式一致性原理与实践》
  • 《Apache ZooKeeper Essetial》

转载地址:http://wemjl.baihongyu.com/

你可能感兴趣的文章
js基础进阶--promise和setTimeout执行顺序的问题
查看>>
mongoose再认识(三)
查看>>
你真的了解RPC吗?
查看>>
Composer简明教程
查看>>
jsonP格式接口实现
查看>>
小窍门-在EXECL表中加入下拉列表
查看>>
INDIGO STUDIO神器!快速创建WEB、移动应用的交互原型工具【转】
查看>>
我的2017云栖之行
查看>>
HSQLDB安装与使用方法
查看>>
重拾C++之初始化
查看>>
maven nexus 下发布第三方构件;
查看>>
Java学习之深拷贝浅拷贝及对象拷贝的两种方式
查看>>
如何根据动态SQL代码自动生成DTO
查看>>
html input="file" 浏览时只显示指定文件类型 xls、xlsx、csv
查看>>
Android Export aborted because fatal error were fo
查看>>
在window平台下模拟Liunx使用GCC环境进行编译C的SO库。
查看>>
原来一直纠结MQ的用法,今天看到了一个最经典的例子。
查看>>
向量空间
查看>>
[日推荐]『共享记账』你的私人会计师!
查看>>
Resource is out of sync with the file system的解决办法
查看>>