二、ZooKeeper集群搭建

目录

1、概述

2、安装

[2.1 第一步:下载zookeeeper压缩包](#2.1 第一步:下载zookeeeper压缩包)

[2.2 第二步:解压](#2.2 第二步:解压)

[2.3 第三步:修改配置文件](#2.3 第三步:修改配置文件)

[2.4 第四步:添加myid配置](#2.4 第四步:添加myid配置)

[​​​​​​​2.5 第五步:安装包分发并修改myid的值](#2.5 第五步:安装包分发并修改myid的值)

[​​​​​​​2.6 第六步:三台机器启动zookeeper服务](#2.6 第六步:三台机器启动zookeeper服务)

[​​​​​​​2.7 配置Path环境变量](#2.7 配置Path环境变量)


1、概述

Zookeeper集群搭建指的是ZooKeeper分布式模式安装。通常由2n+1 台server组成。这是因为为了保证Leader选举(基于Paxos算法的实现)能过得到多数的支持,所以ZooKeeper集群的数量一般为奇数。

2、安装

Zookeeper运行需要java环境,所以需要提前安装jdk 。对于安装leader+follower模式 的集群,大致过程如下:

  1. 配置主机名称到IP地址映射配置
  2. 修改ZooKeeper配置文件
  3. 远程复制分发安装文件
  4. 设置myid
  5. 启动ZooKeeper集群

如果要想使用Observer模式,可在对应节点的配置文件添加如下配置:

peerType=observer

其次,必须在配置文件指定哪些节点被指定为Observer,如:

server.1:node1:2181:3181:observer

其次,必须在配置文件指定哪些节点被指定为 Observer,如:
server.1:localhost:2181:3181:observer

这里,我们安装的是leader+follower模式

|----------------|-------|--------|
| 服务器IP | 主机名 | myid的值 |
| 192.168.88.161 | node1 | 1 |
| 192.168.88.162 | node2 | 2 |
| 192.168.88.163 | node3 | 3 |

2.1 第一步:下载zookeeeper压缩包

下载网址: Index of /dist/zookeeper

我们在这个网址下载我们使用的zk版本为3.4.6

下载完成之后,上传到我们的linux的/export/software路径下准备进行安装

​​​​​​​2.2 第二步: 解压

在node1主机上,解压zookeeper的压缩包到/export/server路径下去,然后准备进行安装

|--------------------------------------------------------------------------------------------------------------|
| cd / export**/** software tar - zxvf zookeeper-3.4.6.tar.gz -C / export**/** server**/** |

​​​​​​​2.3 第三步 :修改 配置 文件

在node1主机上,修改配置文件

|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| cd / export**/** server**/** zookeeper-3.4.6**/** conf**/** cp zoo_sample.cfg zoo.cfg mkdir -p / export**/** server**/** zookeeper-3.4.6**/** zkdatas**/** vim zoo.cfg |

修改以下内容

|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| #Zookeeper的数据存放目录 dataDir**=/** export**/** server**/** zookeeper-3.4.6**/** zkdatas # 保留多少个快照 autopurge.snapRetainCount**=** 3 # 日志多少小时清理一次 autopurge.purgeInterval**=** 1 # 集群中服务器地址 server.1**=** node1**:** 2888**:** 3888 server.2**=** node2**:** 2888**:** 3888 server.3**=** node3**:** 2888**:** 3888 |

​​​​​​​2.4 第四步 添加 myid配置

在node1主机的/export/server/zookeeper-3.4.6/zkdatas/这个路径下创建一个文件,文件名为myid ,文件内容为1

|----------------------------------------------------------------------------------------|
| echo 1 > / export**/** server**/** zookeeper-3.4.6**/** zkdatas**/** myid |

​​​​​​​2.5 第五步 安装包 分发 修改myid的值

在node1主机上,将安装包分发到其他机器

第一台机器上面执行以下两个命令

|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| scp -r / export**/** server**/** zookeeper-3.4.6**/** node2**:/** export**/** server**/** scp -r / export**/** server**/** zookeeper-3.4.6**/** node3**:/** export**/** server**/** |

第二台机器上修改myid的值为2

|----------------------------------------------------------------------------------------|
| echo 2 > / export**/** server**/** zookeeper-3.4.6**/** zkdatas**/** myid |

第三台机器上修改myid的值为3

|----------------------------------------------------------------------------------------|
| echo 3 > / export**/** server**/** zookeeper-3.4.6**/** zkdatas**/** myid |

​​​​​​​2.6 第六步 三台 机器 启动zookeeper 服务

三台机器分别启动zookeeper服务

这个命令三台机器都要执行

|-------------------------------------------------------------------------------|
| / export**/** server**/** zookeeper-3.4.6**/** bin**/** zkServer.sh start |

三台主机分别查看启动状态

|--------------------------------------------------------------------------------|
| / export**/** server**/** zookeeper-3.4.6**/** bin**/** zkServer.sh status |

​​​​​​​2.7 配置Path环境变量

1:分别在三台中,修改/etc/proflie,添加以下内容

export ZOOKEEPER_HOME=/export/server/zookeeper-3.4.6

export PATH=:ZOOKEEPER_HOME/bin:PATH

2:分别在三台主机中,source /etc/profile

至此,ZooKeeper集群搭建完毕。

【下一章】

三、Zookeeper数据模型

【往期回顾】

​​​​​​​一、Zookeeper基本知识

相关推荐
热爱嵌入式的小许5 小时前
Linux基础项目开发1:量产工具——显示系统
linux·运维·服务器·韦东山量产工具
奔跑吧邓邓子5 小时前
大数据利器Hadoop:从基础到实战,一篇文章掌握大数据处理精髓!
大数据·hadoop·分布式
Pythonliu79 小时前
茴香豆 + Qwen-7B-Chat-Int8
linux·运维·服务器
你疯了抱抱我10 小时前
【RockyLinux 9.4】安装 NVIDIA 驱动,改变分辨率,避坑版本。(CentOS 系列也能用)
linux·运维·centos
weixin_4539650010 小时前
[单master节点k8s部署]30.ceph分布式存储(一)
分布式·ceph·kubernetes
weixin_4539650010 小时前
[单master节点k8s部署]32.ceph分布式存储(三)
分布式·ceph·kubernetes
小O_好好学11 小时前
CentOS 7文件系统
linux·运维·centos
哲伦贼稳妥11 小时前
一天认识一个硬件之机房地板
运维·网络·经验分享·其他
john_hjy12 小时前
11. 异步编程
运维·服务器·javascript
x晕x12 小时前
Linux dlsym符号查找疑惑分析
linux·运维·服务器