zooKeeper集群搭建

一、单节点搭建

bash 复制代码
dataDir=/tmp/zookeeper: 这一行指定了ZooKeeper数据和日志文件存储的目录。/tmp/zookeeper是ZooKeeper将保存其事务日志和快照的位置。
clientPort=2181: 定义了客户端连接到ZooKeeper服务器的端口,默认情况下,ZooKeeper监听在2181端口上接收客户端请求。
maxClientCnxns=0: 设置了每个IP地址允许的最大客户端连接数。设置为0表示禁用此限制,即不限制每个IP地址的连接数。在非生产环境中通常这样设置以避免不必要的限制。
admin.enableServer=false: 控制是否启用ZooKeeper的管理界面(admin server)。默认情况下它是禁用的,以避免与其他服务的端口冲突。如果需要使用管理界面,可以将其设置为true。
# admin.serverPort=8080: 这是一行被注释掉的配置,用于指定ZooKeeper管理界面监听的端口号。如果admin.enableServer被设置为true,则可以取消注释并设置一个合适的端口号,例如8080,来启动管理界面。

启动

bash 复制代码
./zookeeper-server-start.sh ../config/zookeeper.properties

nohup ./zookeeper-server-start.sh ../config/zookeeper.properties &

检查启动状态

./zookeeper-shell.sh localhost:2181

二、集群启动

bash 复制代码
tickTime=2000
dataDir=/root/kafka_2.12-3.7.1/data
clientPort=2181
initLimit=10
syncLimit=5
server.1=192.168.43.185:2888:3888
server.2=192.168.43.50:2888:3888
server.3=192.168.43.63:2888:3888

tickTime: ZooKeeper 中使用的基本时间单位(以毫秒为单位),如心跳间隔。

dataDir: 数据文件的目录。

clientPort: 客户端连接到 ZooKeeper 服务器的端口。

initLimit: 在启动时,用于领导选举的时间(tick 数量)。

syncLimit: 用于同步跟随者与领导者的时间(tick 数量)。

server.X: 每个 ZooKeeper 实例的服务器列表。格式为 server.X=hostname:peerPort:leaderElectionPort,其中 X 是服务器编号(从 1 开始),hostname 是服务器的主机名或 IP 地址,peerPort 用于实例间通信,leaderElectionPort 用于领导选举通信。

myid 文件

每个 ZooKeeper 服务器还需要一个 myid 文件,该文件位于 dataDir 目录下,文件内容为该服务器的唯一编号。例如,对于上面的配置:

Server 1:

bash 复制代码
echo "1" > /root/kafka_2.12-3.7.1/data/myid

Server 2:

bash 复制代码
echo "2" > /root/kafka_2.12-3.7.1/data/myid

Server 3:

bash 复制代码
echo "3" > /root/kafka_2.12-3.7.1/data/myid

分别在每台服务器上启动 ZooKeeper 实例:

bash 复制代码
Server 1:
nohup ./zookeeper-server-start.sh ../config/zookeeper.properties &
Server 2:
nohup ./zookeeper-server-start.sh ../config/zookeeper.properties &
Server 3:
nohup ./zookeeper-server-start.sh ../config/zookeeper.properties &
bash 复制代码
使用 zkCli.sh 连接到任意一个 ZooKeeper 实例,执行以下命令查看集群状态:

./zookeeper-shell.sh   192.168.43.185:2181
连接后,可以执行命令 stat 来查看集群状态:

stat
相关推荐
U***e636 小时前
PHP在微服务中的Mezzio
微服务·云原生·架构
u***u6859 小时前
Vue云原生
前端·vue.js·云原生
每天进步一点_JL12 小时前
事务与消息中间件:分布式系统中的可见性边界问题
分布式·后端
ALex_zry14 小时前
Consul全方位入门指南:第二阶段—— 实操。Consul核心功能与项目集成
运维·docker·微服务·云原生·架构
静若繁花_jingjing14 小时前
ZooKeeper & Nacos
分布式·zookeeper·云原生
wanhengidc14 小时前
云手机中分布式存储的功能
运维·服务器·分布式·游戏·智能手机·云计算
TracyCoder12314 小时前
微服务注册中心基础(五):Zookeeper 适用场景
微服务·zookeeper·架构·注册中心
Serverless社区15 小时前
【本不该故障系列】告别资源“不确定性”,SAE如何破解刚性交付核心困境
阿里云·云原生·serverless
u***j32415 小时前
HarmonyOS分布式能力核心技术深度解析
分布式·华为·harmonyos
7***n7515 小时前
HarmonyOS分布式数据管理
分布式·华为·harmonyos