Zookeeper集群搭建

zookeeper官网内容其实已经很详细了。

本文以官网为参考路线:
https://zookeeper.apache.org/doc/current/zookeeperStarted.html

zookeeper事先需要安装jdk,然后下载一个稳定的版本。
具体在:https://zookeeper.apache.org/releases.html
目前已经是3.7了。但是本文搭建还是以3.4.6版本。

下载地址:
https://archive.apache.org/dist/zookeeper/zookeeper-3.4.6/

我们以centos7为例:
目前创建了4个节点:
192.168.33.6
192.168.33.9
192.168.33.7
192.168.33.11

建个目录:

mkdir /usr/soft/zookeeper/

解压 tar.gz

tar -zxvf zookeeper-3.4.6

进入到conf目录:

cd /usr/soft/zookeeper/zookeeper-3.4.6/conf/

conf目录下有一个zoo_sample.cfg的文件。我们拷贝一份命名为zoo.cfg

cp zoo_sample.cfg zoo.cfg

zoo.cfg配置文件需要修改:
主要修改几个部分:

  1. dataDir= /var/zookeeper/data
  2. 添加端口号
    在这里插入图片描述

保存。

我们看一下其他的参数都是什么?
vim

①、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服务器之间的通信端口。

可能遇到的问题

我们在设置端口号之后,需要将centos的端口号开启进行访问。
阿里云的话,需要在阿里云的网站设置配置端口号规则。
虚拟机的话,需要配置规则,配置规则有的是iptables,有的是firewall。也可以简单地将防火墙关闭。

进入到dir目录:
我们创建一个myid文件:

vim myid

并且输入myid为1. 其他的节点需要配置不同的myid。server.2配置为2,server.3配置为3 server.4配置为4.

这样我们就完成了。

我们还可以配置一下环境变量:把zookeeper配置到环境变量中:

export JAVA_HOME=/usr/java/jdk1.8.0_241
export ZOOKEEPER_HOME=/usr/soft/zookeeper/zookeeper-3.4.6
export PATH=$PATH:$JAVA_HOME/bin:$ZOOKEEPER_HOME/bin
export CLASSPATH=.:$JAVA_HOME/jre/lib/rt.jar:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar

当前节点就配置完成了:
我们把相同的配置发送到其他的节点。

scp -r ./zookeeper-3.4.6 192.168.33.7:/usr/soft/zookeeper

同时配置一下myid

好了开始启动:

zkServer.sh为启动命令:
我们可以zkServer.sh help一下,看看都有哪些参数:

在这里插入图片描述
我们使用start-foreground启动。
这样可以在前台看到启动过程。

依次启动每个节点。

启动完成之后:
我们可以看一下状态:

zkServer.sh status

在这里插入图片描述

mode就是follower。当然还有leader.

zkcli命令

我们可以使用zkCli命令来连接这些服务器:常用命令如下;
在这里插入图片描述
我们简单创建一个:
在这里插入图片描述
看看里面都有什么:
在这里插入图片描述
设置进去了:其他的参数代表的是什么意思?
官网上有写:
在这里插入图片描述

简单翻一下:
在这里插入图片描述

ephemeralOwner:这个是创建临时节点的时候的SessionId,持久节点就是0.

首先zookeeper里面会有临时和持久节点。这个节点是数据节点,不是我们说的设备节点。

zookeeper还有顺序节点。

我们创建的时候可以指定这个节点是什么类型:
-s 顺序节点
-e 临时节点

这样我们就创建了一个临时顺序节点;
在这里插入图片描述

客户端和server端,创建的时候是有session的。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值