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

[经验分享] Zookeeper集群的搭建与调试

[复制链接]

尚未签到

发表于 2019-1-7 14:40:53 | 显示全部楼层 |阅读模式
  Zookeeper的下载地址:https://github.com/apache/zookeeper/archive/master.zip
  zkclient的下载地址:https://github.com/sgroschupf/zkclient
  至于zookeeper的作用和原理我这里就不多赘述了,大家有兴趣可以去查查,这里主要就是动手操作。
  搭建集群
  首先先看一下本次zk实验服务器的名称和IP情况,这里我们选择了三台服务器作zkserver,因为三台是标配,一台的话就只有leader没有follower,不是很稳定的结构,当然啦如果你的公司土豪的话是可以玩三十台:
dvl-mrszk-00110.117.0.125
dvl-mrszk-00210.117.1.158
dvl-mrszk-00310.168.152.227
  对这三台服务器要进行如下的步骤:

  1)先把zookeeper.zip传到linux里,然后解压到/usr文件夹下;
  2)进入 /usr/zookeeper/conf文件夹,#vim zoo.cfg,在最下面补充上面的三个zkserver,见图:

  3)再来到/usr/zookeeper/data文件夹,如果里面有文件就清空所有文件,如果是1号zkserver就# echo 1 > myid,如果当前机器是2号zkserver就# echo 2 > myid,依次类推,这里一定要注意,不可以都写一样。
  4)#vim /etc/hosts,还要把这三台机器的ip地址和名字都写进去,如下:
127.0.0.1 localhost
::1         localhost localhost.localdomain localhost6 localhost6.localdomain6
10.117.0.125 dvl-mrszk-001
10.117.1.158 dvl-mrszk-002
10.168.152.227 dvl-mrszk-003  5)再来/usr/zookeeper/bin文件夹,#./zkServer.sh start启动zk,然后再#./zkServer.sh status查看进程情况,如图看见第一台和第三台zkserver的身份是follower,第二台是leader:



  至此整个zk集群就搭建并且启动完成了。

  注意:zookeeper集群时,zookeeper要求半数以上的机器可用,zookeeper才能提供服务。
  如果这里有启动失败的情况,比如'Error contacting service. It is probably not running.'这样的字样,那么有三种可能:
  1)data文件夹下的myid有数字重复或者是数字漏写的情况;
  2)zoo.cfg里的指定日志文件夹没有手动创建;
  3)/etc/hosts下的名字与zoo.cfg里的server字段不相符,注意一下,/etc/hosts里的127.0.0.1的名字不要与本ip后面的名字一模一样,不然zk也无法识别!
  4)/etc/hosts名字使用了中文,java系对中文是很不友好的。
  如果出现的“Cannot open channel to X at election address /A.B.C.D:3888"的日志报错,检查一下zoo.cfg里的123与myid的123是否一致。
  验证成果
  Zookeeper的配置工具叫Zooinspector,下载地址是:
  https://issues.apache.org/jira/secure/attachment/12436620/ZooInspector.zip,下载完直接解压缩就可以在windows里使用。
  我们实验的这三台服务器只有内网,但是如果要连接zooinspector,还是需要通过外网权限连接的,这里可以配一个iptables转发规则,配iptables的步骤在这里:http://chenx1242.blog.运维网.com/10430133/1875950,照葫芦画瓢即可,但是要注意,zk的端口是2181。
  当然,如果不想费事的话,就直接给zkserver 配一个外网IP,直接连接。
  成功连接到zooinspector,就会看到这样的内容,这里的lcconfig是手动添加的,右击鼠标,选择add node,然后直接写上lcconfig就行,这个名字是根据实际需要填写的:

  上面我们已经配置了zkserver集群而且还启动zkserver进程,现在还需要zkclient,zkclient就是请求发起的一方,然后我们可以在各个的模块服务器上部署zkclient服务,通过启动zkclient服务,来让这些模块统一从zooinspector里取值,这样就达到了批量配置,同时保证一致性的效果。
  zk的模板文件是_tpl.properties为结尾的文件,我这里模块的名字叫mrs,那么在实验里这个模板文件就是mrs_tpl.properties,这个mrs_tpl.properties里有这样的一个字段,如图:

  而我们在zooinspector里对应就这么填写:

  保存zooinspector,然后从windows返回到linux,启动zkclient服务和对应的模块进程,如果配置都正常的话,那么程序就会正常启动,# ps -ef|grep java就会看到一个叫“lczk.AppServerDaemon”的进程。这个时候在去看一下mrs的配置文件:

  可以看到areaAk取得值就是zk里面data_center里面access_key里面的ak的值,其他的几个值也是同理。可见整个zk已经配置成功,模块都进行了统一配置,而且这些配置既然能被一个接受,同时也会被其他相同的模块服务器所接受。
  拓展阅读:http://ibruce.info/2014/10/23/zookeeper/




运维网声明 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-660427-1-1.html 上篇帖子: Zookeeper的web管理应用 下篇帖子: 【ZooKeeper Notes 11】ZooKeeper客户端地址列表的随机原理
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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