设为首页 收藏本站
查看: 2867|回复: 0

[经验分享] 单台机器部署zookeeper伪集群

[复制链接]

尚未签到

发表于 2019-1-8 09:51:56 | 显示全部楼层 |阅读模式
  做测试没有多台机器又不想做虚拟机, 通过单独配置zoo.conf实现单机器部署zookeeper集群.
  

  1. 集群配置文件编写
  zookeeper服务1:
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:
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:
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通用即可,下面提供一份简要配置信息:
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集群各个结点的服务
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.查看服务的状态信息
secondriver@ bin$ ./zkServer.sh status ../conf/1.zoo.cfg
JMX enabled by default
Using config: ../conf/1.zoo.cfg
Mode: follower  

secondriver@ bin$ ./zkServer.sh status ../conf/2.zoo.cfg
JMX enabled by default
Using config: ../conf/2.zoo.cfg
Mode: leader  

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服务
  站在客户端的角度看, 客户端独享整个集群.

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服务.
  更多内容参见: http://zookeeper.apache.org/doc/r3.4.6/index.html

  

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

peerType=observer  并且在每个server的配置文件中,配置成Observer模式的server后面追加:observer,如:server.x=host:n:n:observer
  将上面的2181这台服务配置为Observer模式,配置(1.zoo.cfg)如下:
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).




运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-660628-1-1.html 上篇帖子: 单台服务器部署zookeeper集群 下篇帖子: 分布式利器Zookeeper(三)
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表