二、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基本知识

相关推荐
_.Switch1 小时前
高级Python自动化运维:容器安全与网络策略的深度解析
运维·网络·python·安全·自动化·devops
2401_850410831 小时前
文件系统和日志管理
linux·运维·服务器
JokerSZ.1 小时前
【基于LSM的ELF文件安全模块设计】参考
运维·网络·安全
芯盾时代2 小时前
数字身份发展趋势前瞻:身份韧性与安全
运维·安全·网络安全·密码学·信息与通信
心灵彼岸-诗和远方3 小时前
DevOps业务价值流:架构设计最佳实践
运维·产品经理·devops
一只哒布刘3 小时前
NFS服务器
运维·服务器
苹果醋34 小时前
Java8->Java19的初步探索
java·运维·spring boot·mysql·nginx
二十雨辰4 小时前
[linux]docker基础
linux·运维·docker
Jason-河山4 小时前
【自动化更新,让商品信息跳舞】——利用API返回值的幽默编程之旅
运维·自动化
lihuhelihu5 小时前
第3章 CentOS系统管理
linux·运维·服务器·计算机网络·ubuntu·centos·云计算