Zookeeper集群搭建比较简单,主要有以下几个步骤:
- 下载zookeeper,解压
- 创建zoo.cfg,更改相关配置
- 修日志路径,日志规则(可选)
- 分发包,修改myid
环境配置
项目 | 版本 |
---|---|
JDK | 1.8 |
系统 | Centos7 |
Zookeeper | 3.5.5 |
JDK安装 配置
Oracle官网现在JDK1.8 Linux版本tar包,截止到此文章编写时,Zookeeper官方部署说明中要求的时JDK版本要在1.7及1.7以上。
- 上传tar包到服务器解压。创建软链,以便后期JDK版本更新,可以避免更改环境变量。
ln -s jdk1.8.0_11 java
- 配置JDK环境变量
vi ~/.bashrc
配置如下:
- 执行source命令,使环境变量生效
source ~/.bashrc
- 验证
java -version
至此,JDK 配置完成!
ZOOKEEPR安装配置
安装
- 上穿zookeeper tar包,解压,创建软链,与JDK相同,不做赘述。
- 配置环境变量
vi ~/.bashrc
- 执行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
- 更改主要配置,内容如下:
配置说明:
配置项 | 说明 |
---|---|
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官方说明
创建myid
在dataDir
下创建myid文件,内容与server.x对应。
echo 1 >> ~/zkdata/myid
配置日志
zookeeper 3.5.5默认启动日志是放在zookeeper/logs下的,且日志命名方式确定。如果我们需要自定义日志路径,日志命名和滚动规则,就需要更改对应的启动脚本和配置。
- 3.1 日志路径更改
在bin目录下找到zkEnv.sh
可以看到默认的路径,更改这个变量值,就可以以自己指定路径了,更改之后如下:
- 3.2 修改日志命名规则
在bin目录下找到zkServer.sh
修改这个变量值就可以更改命名的格式了。
- 3.3 修改日志滚动方式
首先更改zkEnv.sh
这里修改为
然后修改conf/log4j.properties,主要修改内容如下:
至此日志配置完成。
分发包
将配置好的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