Zookeeper集群搭建

2019-10-27  本文已影响0人  RantLing

Zookeeper集群搭建比较简单,主要有以下几个步骤:

  1. 下载zookeeper,解压
  2. 创建zoo.cfg,更改相关配置
  3. 修日志路径,日志规则(可选)
  4. 分发包,修改myid

环境配置

项目 版本
JDK 1.8
系统 Centos7
Zookeeper 3.5.5

JDK安装 配置

Oracle官网现在JDK1.8 Linux版本tar包,截止到此文章编写时,Zookeeper官方部署说明中要求的时JDK版本要在1.7及1.7以上。

  1. 上传tar包到服务器解压。创建软链,以便后期JDK版本更新,可以避免更改环境变量。
    ln -s jdk1.8.0_11 java
    image.png
  2. 配置JDK环境变量
    vi ~/.bashrc
    配置如下:
    image.png
  3. 执行source命令,使环境变量生效
    source ~/.bashrc
  4. 验证
    java -version
    image.png

至此,JDK 配置完成!

ZOOKEEPR安装配置

安装

  1. 上穿zookeeper tar包,解压,创建软链,与JDK相同,不做赘述。
  2. 配置环境变量
    vi ~/.bashrc
    image.png
  3. 执行source命令,使环境变量生效
    source ~/.bashrc

配置

因为时集群搭建,这里我们以三台节点为例,节点主机名分别为node01,node02,node03。免密和主机名都已经配置过了。
Zookeeper的主要配置文件为zoo.cfg,路径为:$ZOOKEEPER_HOME/conf,初始没有这个文件,只有一个zoo_sample.cfg。我们可以复制一份,或者直接改名,这里我复制了一下。

cd software/zookeeper/conf
cp zoo_sample.cfg  ./zoo.cfg
  1. 更改主要配置,内容如下:
    image.png
    配置说明:
配置项 说明
tickTime 可以理解成一个单位时间,Zookeeper用来确认心跳或超时。例如客户端的最小的超时时间就可以历程成两个tickTime
dataDir Zookeeper用来存放内存中数据快照(snapshot)的目录,如果没有说明,更新的事务(transaction)日志也会存放在这个目录下面
dataLogDir 事务(transaction)日志存放路径,可选项,如果没有配置则为dataDir
clientPort 客户端连接端口
initLimit follower节点去连接和同步leader的时间,单位时tickTime,上图配置就是10个tick Time,即20秒
syncLimit follower节点同步leader的时间,如果follower节点与leader相差太多就会下线
server.x Zookeeper集群节点,节点启动会在dataDir寻找myid,对应节点的x会与myid中数字相同。第一个是follower连接leader的端口号,第二个端口号用来进行leader选举。

更多配置查询Zookeeper官方说明

  1. 创建myid
    dataDir下创建myid文件,内容与server.x对应。
    echo 1 >> ~/zkdata/myid

  2. 配置日志
    zookeeper 3.5.5默认启动日志是放在zookeeper/logs下的,且日志命名方式确定。如果我们需要自定义日志路径,日志命名和滚动规则,就需要更改对应的启动脚本和配置。

修改这个变量值就可以更改命名的格式了。

分发包

将配置好的Zookeeper tar包发送到其他节点上。

scp -r apache-zookeeper-3.5.5-bin node02:/home/zookeeper/software
scp -r apache-zookeeper-3.5.5-bin node03:/home/zookeeper/software

#复制jdk
scp -r jdk1.8.0_11 node02:/home/zookeeper/software
scp -r jdk1.8.0_11 node03:/home/zookeeper/software

#将环境变量复制过去
scp ~/.bashrc  node02:/home/zookeeper/
scp ~/.bashrc  node03:/home/zookeeper/

每个服务器上都要创建软链,执行source命令。
然后启动服务:
zkServer.sh start
验证服务:
zkCli.sh -server localhost:2181

注意,如果启动失败,可能是防火墙没有关闭。可以修改防火墙配置,或者永久关闭防火墙!

上一篇下一篇

猜你喜欢

热点阅读