单台机器部署zookeeper伪集群

本文涉及的产品
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
简介:

做测试没有多台机器又不想做虚拟机, 通过单独配置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结构(如下图所示)


  wKiom1XLI4WhWjHtAAHlXUno0G0567.jpg

  注: 忽略掉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命令可以查看操作命令说明:

wKiom1XLKVWwzqQoAAHLr3mwg1c059.jpg


通过上面命令即可操作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,查看状态,信息如下图:

 wKioL1XVe7uTfVFRAAEqSc8ZXBc638.jpg

  从上图可以看出修改之后,三个server中存在observer,follower,leader。

  注:Zookeeper中follower,leader属于参与者角色(participant),observer属于观察者角色(observer).



本文转自 secondriver 51CTO博客,原文链接:http://blog.51cto.com/aiilive/1684145,如需转载请自行联系原作者

相关实践学习
基于MSE实现微服务的全链路灰度
通过本场景的实验操作,您将了解并实现在线业务的微服务全链路灰度能力。
相关文章
|
4天前
|
Java Shell Linux
Zookeeper单机&集群安装
Zookeeper单机&集群安装
24 1
|
4天前
|
存储 分布式计算 资源调度
Hadoop【环境搭建 04】【hadoop-2.6.0-cdh5.15.2.tar.gz 基于ZooKeeper搭建高可用集群】(部分图片来源于网络)
【4月更文挑战第1天】Hadoop【环境搭建 04】【hadoop-2.6.0-cdh5.15.2.tar.gz 基于ZooKeeper搭建高可用集群】(部分图片来源于网络)
56 3
|
4天前
|
消息中间件 Kafka
Kafka【部署 03】Zookeeper与Kafka自动部署脚本
【4月更文挑战第11天】Kafka【部署 03】Zookeeper与Kafka自动部署脚本
29 8
|
4天前
|
存储 Java 网络安全
ZooKeeper【搭建 03】apache-zookeeper-3.6.0 伪集群版(一台服务器实现三个节点的ZooKeeper集群)
【4月更文挑战第10天】ZooKeeper【搭建 03】apache-zookeeper-3.6.0 伪集群版(一台服务器实现三个节点的ZooKeeper集群)
35 1
|
4天前
|
算法 Java Linux
zookeeper单机伪集群集群部署
zookeeper单机伪集群集群部署
89 0
|
4天前
|
消息中间件 Kubernetes Docker
KubeSphere 核心实战之三【在kubesphere平台上部署ElasticSearch、应用商店部署RabbitMQ和应用市场部署Zookeeper】(实操篇 3/4)
KubeSphere 核心实战之三【在kubesphere平台上部署ElasticSearch、应用商店部署RabbitMQ和应用市场部署Zookeeper】(实操篇 3/4)
50 0
|
4天前
|
消息中间件 存储 Kafka
Kafka【环境搭建 02】kafka_2.11-2.4.1 基于 zookeeper 搭建高可用伪集群(一台服务器实现三个节点的 Kafka 集群)
【2月更文挑战第19天】Kafka【环境搭建 02】kafka_2.11-2.4.1 基于 zookeeper 搭建高可用伪集群(一台服务器实现三个节点的 Kafka 集群)
145 1
|
4天前
|
网络协议 中间件 数据库
Zookeeper学习系列【三】Zookeeper 集群架构、读写机制以及一致性原理(ZAB协议)
Zookeeper学习系列【三】Zookeeper 集群架构、读写机制以及一致性原理(ZAB协议)
117 0
|
4天前
|
网络协议
Zookeeper学习系列【二】Zookeeper 集群章节之集群搭建
Zookeeper学习系列【二】Zookeeper 集群章节之集群搭建
36 0
|
4天前
|
Java
搭建Zookeeper集群的搭建
搭建Zookeeper集群的搭建
39 1