博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
单台机器部署zookeeper伪集群
阅读量:5858 次
发布时间:2019-06-19

本文共 2668 字,大约阅读时间需要 8 分钟。

  做测试没有多台机器又不想做虚拟机, 通过单独配置zoo.conf实现单机器部署zookeeper集群.

 1. 集群配置文件编写

     zookeeper服务1:

clientPort=2181dataDir=/var/data/zookeeper/1.machinetickTime=2000initLimit=5syncLimit=2server.1=127.0.0.1:20881:30881server.2=127.0.0.1:20882:30882server.3=127.0.0.1:20883:30883

    zookeeper服务2:

clientPort=2182dataDir=/var/data/zookeeper/2.machinetickTime=2000initLimit=5syncLimit=2server.1=127.0.0.1:20881:30881server.2=127.0.0.1:20882:30882server.3=127.0.0.1:20883:30883

   zookeeper服务3:

clientPort=2183dataDir=/var/data/zookeeper/3.machinetickTime=2000initLimit=5syncLimit=2server.1=127.0.0.1:20881:30881server.2=127.0.0.1:20882:30882server.3=127.0.0.1:20883:30883

  通常在生产环境下zookeeper集群的各个结点服务都是部署在不同机器上,因此就不用上面这么麻烦,

配置一份zoo.conf通用即可,下面提供一份简要配置信息:

 

clientPort=2183dataDir=/var/data/zookeepertickTime=2000initLimit=5syncLimit=2server.1=server1's-host:20881:30881server.2=server2's-host:20881:30881server.3=server3's-host:20881:30881

注: 在各个服务的配置项的dataDir目录下创建myid文件,写入该服务对应的server后面的数字编号,该数字编号在整个集群中是唯一的取值为[1,255].

2.创建zookeeper集群中各个服务的dataDir结构(如下图所示)

 

  注: 忽略掉x.machine下除myid文件的其他内容,这些内容使由服务启动后产生的.

 

3.启动zookeeper集群各个结点的服务

 

secondriver@ bin$ ./zkServer.sh  start ../conf/1.zoo.cfgsecondriver@ bin$ ./zkServer.sh  start ../conf/2.zoo.cfgsecondriver@ bin$ ./zkServer.sh  start ../conf/3.zoo.cfg

4.查看服务的状态信息

 

secondriver@ bin$ ./zkServer.sh status ../conf/1.zoo.cfg JMX enabled by defaultUsing config: ../conf/1.zoo.cfgMode: follower

secondriver@ bin$ ./zkServer.sh status ../conf/2.zoo.cfg JMX enabled by defaultUsing config: ../conf/2.zoo.cfgMode: leader

secondriver@ bin$ ./zkServer.sh status ../conf/3.zoo.cfg JMX enabled by defaultUsing config: ../conf/3.zoo.cfgMode: follower

 从服务的状态可以看出,个服务正常启动,集群正常运行,1个leader,2个follower

5. 客户端连接zookeeper服务

  站在客户端的角度看, 客户端独享整个集群.

 

secondriver@ bin$ ./zkCli.sh -server 127.0.0.1:2181

 注:应该使一台机器部署多个服务这里需要明确指定server,如果不指定默认使本机监听2181端口的zookeeper服务.

 客户端连接到服务后,控制台打印输出连接建立完成信息如:

 

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服务.

更多内容参见:

6.配置Observer模式

要使用Observer模式的Server,需要在server的配置文件上添加:

 

peerType=observer

 

 并且在每个server的配置文件中,配置成Observer模式的server后面追加:observer,如:server.x=host:n:n:observer

 将上面的2181这台服务配置为Observer模式,配置(1.zoo.cfg)如下:

 

peerType=observerserver.1=127.0.0.1:20881:30881:observerserver.2=127.0.0.1:20882:30882server.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).

转载地址:http://yoejx.baihongyu.com/

你可能感兴趣的文章
Web前端团队开发规范文档
查看>>
spring 常用工具包
查看>>
记录技术(实时服务器)
查看>>
苹果新品发布 Mac和Windows仍要继续并存
查看>>
exec 2.1
查看>>
使用AS直接与服务器TCP通信
查看>>
VB窗体半透明的方法
查看>>
NetSpeeder V3.70 绿色特别版
查看>>
c# 将当前窗体设置为活动窗体
查看>>
Java调用shell命令解压.7z压缩包
查看>>
Percona-Server-5.6.25-73.1二进制rpm包安装
查看>>
JAVA-用HttpClient来模拟浏览器GET,POST
查看>>
安全狗云端+终端服务 将DDOS攻击拦截在“门外”
查看>>
服务器安全软件--服务器安全狗windows V4.2枸杞版发布
查看>>
写给 Android 开发者看的『微信小程序和 Android 开发的对比』
查看>>
Android中按钮的4种响应方式
查看>>
最简单的git使用流程
查看>>
java使用jacob word 转pdf
查看>>
HBase写HLog超时导致RegionServer退出
查看>>
findBugs 快速开始
查看>>