1、apache官方下载,
2、新版本需要jdk环境,然后配置好jdk环境
3、解压zookeeper,进入解压后的conf,新建zoo.cfg (删掉自带的cfg)内容如下
tickTime=2000 initLimit=5 syncLimit=2 dataDir=/usr/local/zookeeper/server1/data dataLogDir=/usr/local/zookeeper/server1/dataLog clientPort=2181 server.1=node1:2888:3888 server.2=node2:2889:3889 server.3=node3:2890:3890
4、检查配置文件里面的datalog 和data 目录是否存在,不然后面启动会报错
5、在每个节点的data目录新建myid文件,并将id值写进去。。。。不然好多报错。按上面配置文件 举个栗子(echo "1" > /usr/local/zookeeper/data/myid) 节点1 就是1, 2就是2
6、启动zookeeper
./zkServer.sh start
启动这个的时候,会在当前路径生产nohup 的一个日志文件,不明白的可看nohup命令
7、查看zookeeper状态 和 在集群种的角色
./zkServer.sh status
启动成功后,可查看本地端口。
2888表示zookeeper程序监听端口,3888表示zookeeper选举通信端口。
之前版本的错误排查
Error contacting service. It is probably not running错误,在网上找了集中解决办法:
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)
如果已存在则去掉
注:在我的zkServer.sh脚本文件里根本没有这一行,所以没有生效
2,
调用sh zkServer.sh status
遇到这个问题。百度,google了后发现有人是修改sh脚本里的一个nc的参数来解决,可在3.4.6的sh文件里并没有找到nc的调用。配置文档里指
定的log目录没有创建导致出错,手动增加目录后重启,问题解决。
注:我想不是日志的问题所以这个方法根本就没有试
3,创建数据目录,也就是在你zoo.cfg配置文件里dataDir指定的那个目录下创建myid文件,并且指定id,改id为你zoo.cfg文件中server.1=localhost:2887:3887中的1.只要在myid头部写入1即可.
注:这是我的解决办法