阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

Zookeeper集群的搭建与调试

455次阅读
没有评论

共计 2950 个字符,预计需要花费 8 分钟才能阅读完成。

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,见图:

Zookeeper 集群的搭建与调试

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:

Zookeeper 集群的搭建与调试

Zookeeper 集群的搭建与调试

Zookeeper 集群的搭建与调试

至此整个 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 系对中文是很不友好的。

验证成果

Zookeeper 的配置工具叫 Zooinspector,下载地址是:

https://issues.apache.org/jira/secure/attachment/12436620/ZooInspector.zip,下载完直接解压缩就可以在 windows 里使用。

我们实验的这三台服务器只有内网,但是如果要连接 zooinspector,还是需要通过外网权限连接的,这里可以配一个 iptables 转发规则,配 iptables 的步骤在这里:http://www.linuxidc.com/Linux/2017-03/141813.htm,照葫芦画瓢即可,但是要注意,zk 的端口是 2181。

当然,如果不想费事的话,就直接给 zkserver 配一个外网 IP,直接连接。

成功连接到 zooinspector,就会看到这样的内容,这里的 lcconfig 是手动添加的,右击鼠标,选择 add node,然后直接写上 lcconfig 就行,这个名字是根据实际需要填写的:

Zookeeper 集群的搭建与调试

上面我们已经配置了 zkserver 集群而且还启动 zkserver 进程,现在还需要 zkclient,zkclient 就是请求发起的一方,然后我们可以在各个的模块服务器上部署 zkclient 服务,通过启动 zkclient 服务,来让这些模块统一从 zooinspector 里取值,这样就达到了批量配置,同时保证一致性的效果。

zk 的模板文件是_tpl.properties 为结尾的文件,我这里模块的名字叫 mrs,那么在实验里这个模板文件就是 mrs_tpl.properties,这个 mrs_tpl.properties 里有这样的一个字段,如图:

Zookeeper 集群的搭建与调试

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

Zookeeper 集群的搭建与调试

 

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

Zookeeper 集群的搭建与调试

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

在 CentOS7 上安装 Zookeeper-3.4.9 服务 http://www.linuxidc.com/Linux/2016-09/135052.htm

ZooKeeper 官方文档翻译——ZooKeeper Overview 3.4.6  http://www.linuxidc.com/Linux/2016-12/138025.htm

CentOS 下 ZooKeeper 3.4.8 集群环境搭建 http://www.linuxidc.com/Linux/2016-12/137958.htm

CentOS 7 下 Zookeeper 集群安装 http://www.linuxidc.com/Linux/2017-01/139733.htm

ZooKeeper 学习总结  http://www.linuxidc.com/Linux/2016-07/133179.htm

Linux 下安装 Zookeeper 集群 http://www.linuxidc.com/Linux/2017-01/139545.htm

Zookeeper3.4.6 的安装 http://www.linuxidc.com/Linux/2015-05/117697.htm

Linux 下 Zookeeper 集群的安装  http://www.linuxidc.com/Linux/2017-03/141400.htm

CentOS 7 下安装 Zookeeper 单机版  http://www.linuxidc.com/Linux/2015-05/117697.htm

本文永久更新链接地址:http://www.linuxidc.com/Linux/2017-03/141812.htm

正文完
星哥玩云-微信公众号
post-qrcode
 0
星锅
版权声明:本站原创文章,由 星锅 于2022-01-21发表,共计2950字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中

星哥玩云

星哥玩云
星哥玩云
分享互联网知识
用户数
4
文章数
19348
评论数
4
阅读量
7818490
文章搜索
热门文章
开发者必备神器:阿里云 Qoder CLI 全面解析与上手指南

开发者必备神器:阿里云 Qoder CLI 全面解析与上手指南

开发者必备神器:阿里云 Qoder CLI 全面解析与上手指南 大家好,我是星哥。之前介绍了腾讯云的 Code...
星哥带你玩飞牛NAS-6:抖音视频同步工具,视频下载自动下载保存

星哥带你玩飞牛NAS-6:抖音视频同步工具,视频下载自动下载保存

星哥带你玩飞牛 NAS-6:抖音视频同步工具,视频下载自动下载保存 前言 各位玩 NAS 的朋友好,我是星哥!...
云服务器部署服务器面板1Panel:小白轻松构建Web服务与面板加固指南

云服务器部署服务器面板1Panel:小白轻松构建Web服务与面板加固指南

云服务器部署服务器面板 1Panel:小白轻松构建 Web 服务与面板加固指南 哈喽,我是星哥,经常有人问我不...
我把用了20年的360安全卫士卸载了

我把用了20年的360安全卫士卸载了

我把用了 20 年的 360 安全卫士卸载了 是的,正如标题你看到的。 原因 偷摸安装自家的软件 莫名其妙安装...
星哥带你玩飞牛NAS-3:安装飞牛NAS后的很有必要的操作

星哥带你玩飞牛NAS-3:安装飞牛NAS后的很有必要的操作

星哥带你玩飞牛 NAS-3:安装飞牛 NAS 后的很有必要的操作 前言 如果你已经有了飞牛 NAS 系统,之前...
阿里云CDN
阿里云CDN-提高用户访问的响应速度和成功率
随机文章
手把手教你,购买云服务器并且安装宝塔面板

手把手教你,购买云服务器并且安装宝塔面板

手把手教你,购买云服务器并且安装宝塔面板 前言 大家好,我是星哥。星哥发现很多新手刚接触服务器时,都会被“选购...
每年0.99刀,拿下你的第一个顶级域名,详细注册使用

每年0.99刀,拿下你的第一个顶级域名,详细注册使用

每年 0.99 刀,拿下你的第一个顶级域名,详细注册使用 前言 作为长期折腾云服务、域名建站的老玩家,星哥一直...
安装Black群晖DSM7.2系统安装教程(在Vmware虚拟机中、实体机均可)!

安装Black群晖DSM7.2系统安装教程(在Vmware虚拟机中、实体机均可)!

安装 Black 群晖 DSM7.2 系统安装教程(在 Vmware 虚拟机中、实体机均可)! 前言 大家好,...
星哥带你玩飞牛NAS-16:不再错过公众号更新,飞牛NAS搭建RSS

星哥带你玩飞牛NAS-16:不再错过公众号更新,飞牛NAS搭建RSS

  星哥带你玩飞牛 NAS-16:不再错过公众号更新,飞牛 NAS 搭建 RSS 对于经常关注多个微...
升级自动部署更新SSL证书系统、申请godaddy的APIKEY

升级自动部署更新SSL证书系统、申请godaddy的APIKEY

升级自动部署更新 SSL 证书系统、申请 godaddy 的 APIKEY 公司之前花钱购买的 ssl 证书快...

免费图片视频管理工具让灵感库告别混乱

一言一句话
-「
手气不错
手把手教你,购买云服务器并且安装宝塔面板

手把手教你,购买云服务器并且安装宝塔面板

手把手教你,购买云服务器并且安装宝塔面板 前言 大家好,我是星哥。星哥发现很多新手刚接触服务器时,都会被“选购...
开发者福利:免费 .frii.site 子域名,一分钟申请即用

开发者福利:免费 .frii.site 子域名,一分钟申请即用

  开发者福利:免费 .frii.site 子域名,一分钟申请即用 前言 在学习 Web 开发、部署...
Prometheus:监控系统的部署与指标收集

Prometheus:监控系统的部署与指标收集

Prometheus:监控系统的部署与指标收集 在云原生体系中,Prometheus 已成为最主流的监控与报警...
三大开源投屏神器横评:QtScrcpy、scrcpy、escrcpy 谁才是跨平台控制 Android 的最优解?

三大开源投屏神器横评:QtScrcpy、scrcpy、escrcpy 谁才是跨平台控制 Android 的最优解?

  三大开源投屏神器横评:QtScrcpy、scrcpy、escrcpy 谁才是跨平台控制 Andr...
多服务器管理神器 Nexterm 横空出世!NAS/Win/Linux 通吃,SSH/VNC/RDP 一站式搞定

多服务器管理神器 Nexterm 横空出世!NAS/Win/Linux 通吃,SSH/VNC/RDP 一站式搞定

多服务器管理神器 Nexterm 横空出世!NAS/Win/Linux 通吃,SSH/VNC/RDP 一站式搞...