您的位置:首页 > 运维架构 > Linux

Linux配置zookeeper时:Error contacting service. It is probably not runnin

2017-08-14 17:51 435 查看
文章部分内容摘自:http://www.cnblogs.com/xiaohua92/p/5460515.html

今天试了zookeeper的安装,正常启动了2台,可是有一台就是起不来,于是在网上各种找答案:

有一个哥们的答案:

安装zookeeper-3.3.2的时候,启动正常没报错,但zkServer.sh status查看状态的时候却出现错误,如下:

JMX enabled by default

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

Error contacting service. It is probably not running.

jps查看进程,却发现进程已启动

7313 QuorumPeerMain

在网上查阅资料一共有三种解决方法:

1,打开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是3.4.5版本,所以在我的zkServer.sh脚本文件里根本没有这一行,所以没有生效

2,调用sh zkServer.sh status 遇到这个问题。百度,google了后发现有人是修改sh脚本里的一个nc的参数来解决,可在3.4.5的sh文件里并没有找到nc的调用。配置文档里指定的log目录没有创建导致出错,手动增加目录后重启,问题解决。

注:我想不是日志的问题所以这个方法根本就没有试

3,创建数据目录,也就是在你zoo.cfg配置文件里dataDir指定的那个目录下创建myid文件,并且指定id,改id为你zoo.cfg文件中server.1=localhost:2888:3888中的 1.只要在myid头部写入1即可.

注:在我第二次安装的时候,没有将myid文件创建在dataDir指定的那个目录下,也报了该错误。之后在dataDir指定的那个目录下创建myid文件就没有报错。

4 因为防火墙没有关闭。关闭防火墙:

#查看防火墙状态

service iptables status

#关闭防火墙

service iptables stop

#查看防火墙开机启动状态

chkconfig iptables --list

#关闭防火墙开机启动

chkconfig iptables off

注意:我的确在开始时候没有关闭防火墙,但是当我关闭防火墙之后也没有解决问题。

5 没有建立主机和ip之间的映射关系。

建立主机和ip之间映射关系的命令为 vim /etc/hosts 在文件的末端加入各个主机和ip地址之间的映射关系就可以了。

注意:只有在建立了映射关系之后,才可以将在同一个网段下的机器利用主机名进行文件传递。问题解决!
以上摘自开链接的博客内容。

按照以上内容进行检查后,发现还是没有解决我的问题,突然在zookeeper.log看到一个日志:

也不知道是不是这个错误,就顺藤摸瓜,看看我的环境变量是否配置错误,检查之后,是有点问题,就修改了/etc/profile,直接从正常机器copy了配置环境变量的那一段代码;

然后重新启动三台机器的zookeeper服务,竟然正常启动了。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  zookeeper linux
相关文章推荐