搭建JEESZ分布式架构6--ZooKeeper 集群的安装

ZooKeeper是一个分布式开源框架,提供了协调分布式应用的基本服务,它向外部应用暴露一组通用服务——分布式同步(Distributed Synchronization).命名服务(Naming Service).集群维护(Group Maintenance)等,简化分布式应用协调及其管理的难度,提供高性能的分布式服务。ZooKeeper本身可以以Standalone模式安装运行,不过它的长处在于通过分布式ZooKeeper集群(一个Leader,多个Follower),基于一定的策略来保证ZooKeeper集群的稳定性和可用性,从而实现分布式应用的可靠性。(我是网上抄写的,方便大家学习,请勿吐槽!!)

Dubbo 建议使用 Zookeeper 作为服务的注册中心。 

Zookeeper 集群中只要有过半的节点是正常的情况下,那么整个集群对外就是可用的。

正是基于这个 特性,要将 zookeeper集群的节点数量要为奇数(2n+1:如 3、5、7 个节点)

声明:以上都是官网的原话,此教程主要是供大家学习,请各位不要吐槽

根据您自己的业务来决定服务器配置,我这边定义了三台服务器,如下:

服务器1:xxx.xxx.xxx.xx1  端口:2181、2881、3881 

服务器2:xxx.xxx.xxx.xx2  端口:2182、2882、3882 

服务器3:xxx.xxx.xxx.xx3  端口:2183、2883、3883

1、 修改操作系统的/etc/hosts 文件,添加 IP 与主机名映射:

[root@cloud   ~]# vi /etc/hosts

# zookeeper servers

xxx.xxx.xxx.xx1 jeesz-zk-01

xxx.xxx.xxx.xx2 jeesz-zk-02

xxx.xxx.xxx.xx3 jeesz-zk-03

2、 下载或上传 zookeeper-3.4.6.tar.gz 到/home/jeesz/zookeeper 目录:

[root@cloud   ~]# cd/home/jeesz/zookeeper

$ wgethttp://apache.fayea.com/zookeeper/zookeeper-3.4.6/zookeeper-3.4.6.tar.gz

3、 由于我已经下载并上传了文件,故这边直接记录详细的安装过程,解压 zookeeper 安装包,并按节点号对 zookeeper 目录重命名:

[root@cloud   zookeeper]# tar -zxvfzookeeper-3.4.6.tar.gz

在xxx.xxx.xxx.xx1服务器:

[root@cloud   zookeeper]# mvzookeeper-3.4.6 node-01

在xxx.xxx.xxx.xx2服务器:

[root@cloud   zookeeper]# mvzookeeper-3.4.6 node-02

在xxx.xxx.xxx.xx3服务器:

[root@cloud  zookeeper]# mvzookeeper-3.4.6 node-03

4、 分别在 zookeeper 节点目录下创建以下目录:

[root@cloud  ~]# /home/jeesz/zookeeper/node-0X (X 代表节点号 1、2、3)

[root@cloud  node-0X]# mkdirdata

[root@cloud  node-0X] # mkdirlogs

5、 将 zookeeper/node-0X/conf 目录下的 zoo_sample.cfg 文件拷贝一份,命名为 zoo.cfg:

[root@cloud  conf] cp zoo_sample.cfgzoo.cfg

6、 修改 zoo.cfg 配置文件:

[root@cloud conf] # vi zoo.cfg

zookeeper/node-01 的配置(/home/jeesz/zookeeper/node-01/conf/zoo.cfg)如下:

dataDir=/home/jeesz/zookeeper/node-01/data

dataLogDir=/home/jeesz/zookeeper/node-01/logs

clientPort=2181

server.1=jeesz-zk-01:2881:3881

server.2=jeesz-zk-02:2882:3882

server.3=jeesz-zk-03:2883:3883

 

zookeeper/node-02 的配置(/home/jeesz/zookeeper/node-02/conf/zoo.cfg)如下:

dataDir=/home/jeesz/zookeeper/node-02/data

dataLogDir=/home/jeesz/zookeeper/node-02/logs

clientPort=2182

server.1=jeesz-zk-01:2881:3881

server.2= jeesz -zk-02:2882:3882

server.3= jeesz -zk-03:2883:3883

zookeeper/node-03 的配置(/home/jeesz/zookeeper/node-03/conf/zoo.cfg)如下:

dataDir=/home/jeesz/zookeeper/node-03/data

dataLogDir=/home/jeesz/zookeeper/node-03/logs

clientPort=2183

server.1= jeesz-zk-01:2881:3881

server.2= jeesz-zk-02:2882:3882

server.3= jeesz-zk-03:2883:3883

7、 在dataDir=/home/jeesz/zookeeper/node-0X/data 下创建 myid 文件

编辑 myid 文件,并在对应的IP 的机器上输入对应的编号。如在 node-01 上,myid文件内容就是

1,node-02 上就是 2,node-03 上就是 3:

[root@cloud  ~]# vi/home/jeesz/zookeeper/node-01/data/myid 

1

[root@cloud  ~]# vi/home/jeesz/zookeeper/node-02/data/myid 

2

[root@cloud  ~]# vi/home/jeesz/zookeeper/node-03/data/myid 

3

8、 在防火墙中打开要用到的端口 218X、288X、388X

[root@cloud  ~]# vi/etc/sysconfig/iptables

如服务器 01 增加以下 3 行:

## zookeeper

-A INPUT -m state --state NEW -m tcp -p tcp--dport 2181 -j ACCEPT

-A INPUT -m state --state NEW -m tcp -p tcp--dport 2881 -j ACCEPT

-A INPUT -m state --state NEW -m tcp -p tcp--dport 3881 -j ACCEPT

重启防火墙:

[root@cloud  ~]# serviceiptables restart

查看防火墙端口状态:

[root@cloud  ~]# serviceiptables status

注意:centos7中使用方法不同,大家可以上网查询一下

9、 启动并测试 zookeeper(要用 jeesz 用户启动,不要用 root):

(1) 到/home/jeesz/zookeeper/node-0X/bin 目录中执行:

[root@cloud  ~]# /home/jeesz/zookeeper/node-01/bin/zkServer.shstart

[root@cloud  ~]# /home/jeesz/zookeeper/node-02/bin/zkServer.shstart

[root@cloud  ~]# /home/jeesz/zookeeper/node-03/bin/zkServer.shstart

(2) 输入 jps 命令查看进程: 

[root@cloud  ~]# jps

1456 QuorumPeerMain

其中,QuorumPeerMain 是 zookeeper 进程,说明启动正常

(3) 查看状态:

[root@cloud  ~]# /home/jeesz/zookeeper/node-01/bin/zkServer.sh status

(4) 查看 zookeeper 服务输出信息:

由于服务信息输出文件在/home/jeesz/zookeeper/node-0X/bin/zookeeper.out

[root@cloud  ~]# tail-500f zookeeper.out

10、停止 zookeeper 进程:

[root@cloud  ~]# zkServer.shstop

11、配置 zookeeper 开机使用 jeesz 用户启动:

编辑 node-01、node-02、node-03 中的/etc/rc.local 文件,分别加入:

[root@cloud  ~]# vi/etc/rc.local

su - root -c'/home/jeesz/zookeeper/node-01/bin/zkServer.sh start'

su - root -c '/home/jeesz/zookeeper/node-02/bin/zkServer.shstart'

su - root -c'/home/jeesz/zookeeper/node-03/bin/zkServer.sh start'

 

想了解更多详细请点击源码地址获取mingli.com

有兴趣的朋友们可以前往球球哦~一起分享学习技术:2042849237

请大家持续关注搭建JEESZ分布式架构7--Zookeeper注册中心安装

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/31456321/viewspace-2139064/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/31456321/viewspace-2139064/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
提供的源码资源涵盖了安卓应用、小程序、Python应用和Java应用等多个领域,每个领域都包含了丰富的实例和项目。这些源码都是基于各自平台的最新技术和标准编写,确保了在对应环境下能够无缝运行。同时,源码中配备了详细的注释和文档,帮助用户快速理解代码结构和实现逻辑。 适用人群: 这些源码资源特别适合大学生群体。无论你是计算机相关专业的学生,还是对其他领域编程感兴趣的学生,这些资源都能为你提供宝贵的学习和实践机会。通过学习和运行这些源码,你可以掌握各平台开发的基础知识,提升编程能力和项目实战经验。 使用场景及目标: 在学习阶段,你可以利用这些源码资源进行课程实践、课外项目或毕业设计。通过分析和运行源码,你将深入了解各平台开发的技术细节和最佳实践,逐步培养起自己的项目开发和问题解决能力。此外,在求职或创业过程中,具备跨平台开发能力的大学生将更具竞争力。 其他说明: 为了确保源码资源的可运行性和易用性,特别注意了以下几点:首先,每份源码都提供了详细的运行环境和依赖说明,确保用户能够轻松搭建起开发环境;其次,源码中的注释和文档都非常完善,方便用户快速上手和理解代码;最后,我会定期更新这些源码资源,以适应各平台技术的最新发展和市场需求。
提供的源码资源涵盖了安卓应用、小程序、Python应用和Java应用等多个领域,每个领域都包含了丰富的实例和项目。这些源码都是基于各自平台的最新技术和标准编写,确保了在对应环境下能够无缝运行。同时,源码中配备了详细的注释和文档,帮助用户快速理解代码结构和实现逻辑。 适用人群: 这些源码资源特别适合大学生群体。无论你是计算机相关专业的学生,还是对其他领域编程感兴趣的学生,这些资源都能为你提供宝贵的学习和实践机会。通过学习和运行这些源码,你可以掌握各平台开发的基础知识,提升编程能力和项目实战经验。 使用场景及目标: 在学习阶段,你可以利用这些源码资源进行课程实践、课外项目或毕业设计。通过分析和运行源码,你将深入了解各平台开发的技术细节和最佳实践,逐步培养起自己的项目开发和问题解决能力。此外,在求职或创业过程中,具备跨平台开发能力的大学生将更具竞争力。 其他说明: 为了确保源码资源的可运行性和易用性,特别注意了以下几点:首先,每份源码都提供了详细的运行环境和依赖说明,确保用户能够轻松搭建起开发环境;其次,源码中的注释和文档都非常完善,方便用户快速上手和理解代码;最后,我会定期更新这些源码资源,以适应各平台技术的最新发展和市场需求。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值