linux查看zookeeper端口,linux下启动zookeeper成功但是查看状态status出错

昨天弄了一整天的zookeeper的安装和启动,一直出现各种各种错误,现在记录一下,希望能帮助到后来的朋友。

zookeeper的安装教程一找一大堆,这里就不赘述了,简单的描述一下:

1、下载zookeeper(当然在安装zookeeper之前得先装好jdk,这里就不说了),版本自己随便选一个(后面我再说版本的问题),点击这里下载。

2、然后在usr下创建zookeeper文件夹,把下载的tar包扔进去,再解压缩。

3、之后在解压缩的根目录创建data文件夹,如下:

f1aa802d0e07c3a200a31c0210aeb8c4.png

4、创建好之后进入data文件夹,pwd命令获取到data文件夹的绝对路径。复制data的绝对路径,返回上一级,打开conf文件夹,重命名conf文件夹下的zoo_samle.cfg为zoo.cfg,再打开编辑zoo.cfg,更改dataDir的位置为刚刚复制的data目录的绝对路径:

c9ba4133d9d80ca88f46dbc9a1899f93.png

5、到这里就已经全部安装好了,进入解压后的根目录下面的bin目录执行:./zkServer.sh start执行开启zookeeper就可以了。

好了,下面来说说我遇到的各种烦人的问题。

一开始我使用的是zookeeper-3.4.6.tar.gz版本,启动的时候显示启动成功,但是查看状态时./zkServer.sh status有错误:

JMX enabled by default

Using config: /usr/zookeeper/bin/../conf/zoo.cfg

Error contacting service. It is probably not running.

就是上面这个错误,然后就开始在网上找各种解决办法,关闭防火墙,查看端口号是否被占用等等。发现这些都没有问题。

然后又看到有说nc和localhost的问题:

打开编辑zkServer.sh(注意是编辑这个脚本,不是执行)

找到:status)

STAT=`echo stat | nc localhost $(grep clientPort "$ZOOCFG" | sed -e 's/.*=//') 2> /dev/null| grep Mode`

在nc与localhost之间加上 -q 1 (是数字1而不是字母l)

但是我发现我的zookeeper版本的zkServer.sh里面根本没有这句话。然后我继续找解决方案。

看到有说缺少myid文件的,因为我的是本地运行,所以conf/zoo.cfg后面没有server.1=localhost:2888:3888这个,只有上面那五行配置。所以也就不存在myid文件缺失的问题,但是我还是尝试着去创建了myid文件并写入一个数字,发现还是不行。

最后发现是不是我的zookeeper版本有问题,于是就换了高点的版本,换到了zookeeper3.4.x,发现还是不行,直接就启动失败。于是我再换,换成zookeeper3.5.x发现还是不行,也是直接start failed。最后实在没办法了,换成了低版本的zookeeper3.3.6一次性就成功了,没有什么其他的设置,就是创建data目录,然后复制绝对路径到conf/zoo.cfg中的dataDir修改就行了,也没有配置什么环境变量。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值