zookeeper的默认配置文件为zookeeper/conf/zoo_sample.cfg,需要将其修改为zoo.cfg。其中各配置项的含义,解释如下:
1.tickTime:CS通信心跳时间
Zookeeper 服务器之间或客户端与服务器之间维持心跳的时间间隔,也就是每个 tickTime 时间就会发送一个心跳。tickTime以毫秒为单位。
tickTime=2000
2.initLimit:LF初始通信时限
集群中的follower服务器(F)与leader服务器(L)之间初始连接时能容忍的最多心跳数(tickTime的数量)。
initLimit=5
3.syncLimit:LF同步通信时限
集群中的follower服务器与leader服务器之间请求和应答之间能容忍的最多心跳数(tickTime的数量)。
syncLimit=2
4.dataDir:数据文件目录
Zookeeper保存数据的目录,默认情况下,Zookeeper将写数据的日志文件也保存在这个目录里。
dataDir=/home/michael/opt/zookeeper/data
5.clientPort:客户端连接端口
客户端连接 Zookeeper 服务器的端口,Zookeeper 会监听这个端口,接受客户端的访问请求。
clientPort=2181
6.服务器名称与地址:集群信息(服务器编号,服务器地址,LF通信端口,选举端口)
这个配置项的书写格式比较特殊,规则如下:
server.N=YYY:A:B
server.1=itcast05:2888:3888
server.2=itcast06:2888:3888
server.3=itcast07:2888:3888
bin/zkServer.sh start 启动
常见问题:
Zookeeper启动成功,zkServer.sh status 报错
当安装zookeeper集群启动后,使用jps能看zookeeper的进程。但是使用zkServer.sh status 看出角色时报Error contacting service. It is probably not running.的错误。网上很多人说是nc的问题,但是我使用的是3.4.5版本,zkServer.sh中status)中没有nc.后来经过一番分析,发现不知道是什么时候防火墙打开了。关闭了防火墙就成功了。真是郁闷,浪费一晚上时间。
1.使用service iptables stop 关闭防火墙
2.使用service iptables status确认
3.避免下次开机防火墙自启动。使用chkconfig iptables off禁用防火墙