Zookeeper集群搭建

1、环境准备

使用Virtual Box安装了三台 Linux虚拟机,并且要相互ping能网络
	192.168.66.100
	192.168.66.101
	192.168.66.102

2、zookeeper角色职责

zookeeper 集群通常是用来对用户的分布式应用程序提供协调服务的,为了保证数据的一致性,对 zookeeper 集群进行了这样三种角色划分:leader、follower、observer分别对应着总统、议员和观察者。
  总统(leader):负责进行投票的发起和决议,更新系统状态。
  议员(follower):用于接收客户端请求并向客户端返回结果以及在选举过程中参与投票。
  观察者(observer):也可以接收客户端连接,将写请求转发给leader节点,但是不参与投票过程,只同步leader的状态。通常对查询操作做负载。

3、下载zookeeper安装包

https://zookeeper.apache.org/releases.html

4、安装JDK才能运行zookeeper

由于zookeeper的运行需要依赖JDK环境

4.1 根据自己的系统下载对应的jdk

https://www.oracle.com/cn/java/technologies/javase/javase-jdk8-downloads.html
在这里插入图片描述

4.2 解压到指定的目录

在这里插入图片描述

4.3 配置JDK的环境变量
vi /etc/profile

在这里插入图片描述

4.4 更改为自己对应的路径
export JAVA_HOME=/usr/local/java/jdk1.8.0_131
export JRE_HOME=${JAVA_HOME}/jre
export CLASSPATH=.:${JAVA_HOME}/lib:${JRE_HOME}/lib
export PATH=${JAVA_HOME}/bin:$PATH
4.5 刷新配置文件
source /etc/profile

5、解压zookeeper安装包

5.1解压到指定的路径

在这里插入图片描述

5.2 复制zoo_sample.cfg文件,并修改文件名为zoo.cfg

在这里插入图片描述

5.3修改zoo.cfg的配置

![在这里插入图片描述](https://img-blog.csdnimg.cn/20210616110403352.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzM2MzYzNDk5,size_16,color_FFFFFF,t_70
在这里插入图片描述
①、tickTime:基本事件单元,这个时间是作为Zookeeper服务器之间或客户端与服务器之间维持心跳的时间间隔,每隔tickTime时间就会发送一个心跳;最小 的session过期时间为2倍tickTime

②、dataDir:存储内存中数据库快照的位置,除非另有说明,否则指向数据库更新的事务日志。注意:应该谨慎的选择日志存放的位置,使用专用的日志存储设备能够大大提高系统的性能,如果将日志存储在比较繁忙的存储设备上,那么将会很大程度上影像系统性能。

③、client:监听客户端连接的端口。

④、initLimit:允许follower连接并同步到Leader的初始化连接时间,以tickTime为单位。当初始化连接时间超过该值,则表示连接失败。

⑤、syncLimit:表示Leader与Follower之间发送消息时,请求和应答时间长度。如果follower在设置时间内不能与leader通信,那么此follower将会被丢弃。

⑥、server.A=B:C:D

A:其中 A 是一个数字,表示这个是服务器的编号;

B:是这个服务器的 ip 地址;

C:Leader选举的端口;

D:Zookeeper服务器之间的通信端口。

我们需要修改的第一个是 dataDir ,在指定的位置处创建好目录。

第二个需要新增的是 server.A=B:C:D 配置,其中 A 对应下面我们即将介绍的myid 文件。B是集群的各个IP地址,C:D 是端口配置。

5.4 创建myid文件

在这里插入图片描述
去到这个目录下
在这里插入图片描述

配置zookeeper的环境变量

不需要每次启动都要去到安装目录的bin目录下

vi /etc/profile

在这里插入图片描述
注意自己zookeeper安装的路径,别写错了,亲

刷新一下配置文件

source /etc/profile

其他两台机器按以上同样的操作,其实也可以使用rsync命令进行分发安装包

6、启动zookeeper

在启动zookeeper之前,查看一下各机器的防火墙是否已经关闭

systemctl status firewalld

在这里插入图片描述

关闭防火墙命令
systemctl disable firewalld
或停止
systemctl stop firewalld
分别启动zookeeper
zkServer.sh start
查看各节点的zookeeper的状态
zkServer.sh status

在这里插入图片描述
登录上zookeeper,查看节点数

zkCli.sh -server 192.168.66.102:2181
ls /brokers/ids
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值