做测试没有多台机器又不想做虚拟机, 通过单独配置zoo.conf实现单机器部署zookeeper集群.
1. 集群配置文件编写
zookeeper服务1:
1
2
3
4
5
6
7
8
|
clientPort=2181
dataDir=
/var/data/zookeeper/1
.machine
tickTime=2000
initLimit=5
syncLimit=2
server.1=127.0.0.1:20881:30881
server.2=127.0.0.1:20882:30882
server.3=127.0.0.1:20883:30883
|
zookeeper服务2:
1
2
3
4
5
6
7
8
|
clientPort=2182
dataDir=
/var/data/zookeeper/2
.machine
tickTime=2000
initLimit=5
syncLimit=2
server.1=127.0.0.1:20881:30881
server.2=127.0.0.1:20882:30882
server.3=127.0.0.1:20883:30883
|
zookeeper服务3:
1
2
3
4
5
6
7
8
|
clientPort=2183
dataDir=
/var/data/zookeeper/3
.machine
tickTime=2000
initLimit=5
syncLimit=2
server.1=127.0.0.1:20881:30881
server.2=127.0.0.1:20882:30882
server.3=127.0.0.1:20883:30883
|
通常在生产环境下zookeeper集群的各个结点服务都是部署在不同机器上,因此就不用上面这么麻烦,
配置一份zoo.conf通用即可,下面提供一份简要配置信息:
1
2
3
4
5
6
7
8
|
clientPort=2183
dataDir=
/var/data/zookeeper
tickTime=2000
initLimit=5
syncLimit=2
server.1=server1's-host:20881:30881
server.2=server2's-host:20881:30881
server.3=server3's-host:20881:30881
|
注: 在各个服务的配置项的dataDir目录下创建myid文件,写入该服务对应的server后面的数字编号,该数字编号在整个集群中是唯一的取值为[1,255].
2.创建zookeeper集群中各个服务的dataDir结构(如下图所示)
注: 忽略掉x.machine下除myid文件的其他内容,这些内容使由服务启动后产生的.
3.启动zookeeper集群各个结点的服务
1
2
3
|
secondriver@ bin$ .
/zkServer
.sh start ..
/conf/1
.zoo.cfg
secondriver@ bin$ .
/zkServer
.sh start ..
/conf/2
.zoo.cfg
secondriver@ bin$ .
/zkServer
.sh start ..
/conf/3
.zoo.cfg
|
4.查看服务的状态信息
1
2
3
4
|
secondriver@ bin$ .
/zkServer
.sh status ..
/conf/1
.zoo.cfg
JMX enabled by default
Using config: ..
/conf/1
.zoo.cfg
Mode: follower
|
1
2
3
4
|
secondriver@ bin$ .
/zkServer
.sh status ..
/conf/2
.zoo.cfg
JMX enabled by default
Using config: ..
/conf/2
.zoo.cfg
Mode: leader
|
1
2
3
4
|
secondriver@ bin$ .
/zkServer
.sh status ..
/conf/3
.zoo.cfg
JMX enabled by default
Using config: ..
/conf/3
.zoo.cfg
Mode: follower
|
从服务的状态可以看出,个服务正常启动,集群正常运行,1个leader,2个follower
5. 客户端连接zookeeper服务
站在客户端的角度看, 客户端独享整个集群.
1
|
secondriver@ bin$ .
/zkCli
.sh -server 127.0.0.1:2181
|
注:应该使一台机器部署多个服务这里需要明确指定server,如果不指定默认使本机监听2181端口的zookeeper服务.
客户端连接到服务后,控制台打印输出连接建立完成信息如:
1
2
3
4
|
2015-08-12 18:45:49,265 [myid:] - INFO
[main-SendThread(127.0.0.1:2181):ClientCnxn$SendThread@1235] -
Session establishment complete on server 127.0.0.1
/127
.0.0.1:2181,
sessionid = 0x14f2139e5630002, negotiated timeout = 30000
|
输入help命令可以查看操作命令说明:
通过上面命令即可操作zookeeper服务.
更多内容参见: http://zookeeper.apache.org/doc/r3.4.6/index.html
6.配置Observer模式
要使用Observer模式的Server,需要在server的配置文件上添加:
1
|
peerType=observer
|
并且在每个server的配置文件中,配置成Observer模式的server后面追加:observer,如:server.x=host:n:n:observer
将上面的2181这台服务配置为Observer模式,配置(1.zoo.cfg)如下:
1
2
3
4
|
peerType=observer
server.1=127.0.0.1:20881:30881:observer
server.2=127.0.0.1:20882:30882
server.3=127.0.0.1:20883:30883
|
同样更新2.zoo.cfg, 3.zoo.cfg中server.1的值和1.zoo.cfg一致。一并启动这三个server,查看状态,信息如下图:
从上图可以看出修改之后,三个server中存在observer,follower,leader。
注:Zookeeper中follower,leader属于参与者角色(participant),observer属于观察者角色(observer).
本文转自 secondriver 51CTO博客,原文链接:http://blog.51cto.com/aiilive/1684145,如需转载请自行联系原作者