ZK集群搭建:详细步骤与注意事项
在大数据和分布式系统日益重要的今天,ZooKeeper(简称ZK)作为一种分布式协调服务,扮演着举足轻重的角色。它主要用于管理大型分布式系统中的配置信息、命名、同步等。下面将详细介绍如何搭建一个ZooKeeper集群,帮助大家掌握这一关键技能。

0x00、准备工作
硬件与软件准备
硬件:至少需要三台服务器(或虚拟机)来搭建一个基本的ZooKeeper集群。
| 服务器 | 系统 | CPU | 内存 | IP |
|---|---|---|---|---|
| cvm1 | CentOS 7.6 | 4核 | 8G | 172.20.0.10 |
| cvm2 | CentOS 7.6 | 4核 | 8G | 172.20.0.16 |
| cvm3 | CentOS 7.6 | 4核 | 8G | 172.20.0.17 |
软件:每台服务器需要安装JDK(Java Development Kit),因为ZooKeeper是用Java编写的。建议使用JDK 1.8或更高版本。
网络配置
为每台服务器分配一个唯一的IP地址,并在/etc/hosts文件中配置主机名和IP地址的映射关系,以便ZooKeeper集群内部能够相互通信。
0x01、安装JDK
下载JDK安装包
从Oracle官网或其他可信的JDK下载源获取JDK安装包。
解压并安装JDK
使用tar命令解压JDK安装包,并将其移动到合适的目录,例如/data/jdk/。
配置环境变量
编辑/etc/profile文件,添加以下环境变量:
export JAVA_HOME=/data/zk/jdk1.8.0_xxx
export PATH=$PATH:$JAVA_HOME/bin
保存并退出,然后执行下面的命令使配置生效。
source /etc/profile
0x02、下载并安装ZooKeeper
下载ZooKeeper安装包
从ZooKeeper官网(https://zookeeper.apache.org/)下载最新版本的ZooKeeper安装包。
解压并安装ZooKeeper
使用tar命令解压ZooKeeper安装包,并将其移动到合适的目录,例如/data/zk/。
配置ZooKeeper
进入ZooKeeper的conf目录,复制zoo-sample.cfg文件并重命名为zoo.cfg。

编辑zoo.cfg文件,进行以下配置:
# The number of milliseconds of each tick
tickTime=2000
# The number of ticks that the initial
# synchronization phase can take
initLimit=10
# The number of ticks that can pass between
# sending a request and getting an acknowledgement
syncLimit=5
# the directory where the snapshot is stored.
# do not use /tmp for storage, /tmp here is just
# example sakes.
dataDir=/data/zookeeper_data
# the port at which the clients will connect
clientPort=2181
# the maximum number of client connections.
# increase this if you need to handle more clients
#maxClientCnxns=60
#
# Be sure to read the maintenance section of the
# administrator guide before turning on autopurge.
#
# http://zookeeper.apache.org/doc/current/zookeeperAdmin.html#sc_maintenance
#
# The number of snapshots to retain in dataDir
#autopurge.snapRetainCount=3
# Purge task interval in hours
# Set to "0" to disable auto purge feature
#autopurge.purgeInterval=1
server.1=172.20.0.10:2888:3888
server.2=172.20.0.16:2888:3888
server.3=172.20.0.17:2888:3888
创建myid文件
在每台服务器的dataDir目录下创建myid文件,文件内容应为服务器的编号(与zoo.cfg中的server.X对应)。
0x03、部署ZooKeeper集群
复制ZooKeeper安装包到其他服务器
使用scp命令将ZooKeeper安装包复制到其他两台服务器。
配置其他服务器的myid文件
在其他两台服务器的dataDir目录下创建myid文件,并分别填写对应的服务器编号。
启动ZooKeeper服务
在每台服务器的ZooKeeper安装目录下的bin目录中,执行./zkServer.sh start命令启动ZooKeeper服务。
cd /data/apache-zookeeper-3.5.9-bin/bin
./zkServer.sh start
使用./zkServer.sh status命令查看ZooKeeper服务的状态。

0x04、验证ZooKeeper集群
检查集群状态
在任意一台服务器上执行./zkServer.sh status命令,查看集群状态。正常情况下,会有一台服务器被选举为leader,其他服务器为follower。

测试数据同步
使用ZooKeeper客户端连接到任意一台服务器,创建节点并设置值。
cd /data/apache-zookeeper-3.5.9-bin/bin
./zkCli.sh -server 172.20.0.10:2181,172.20.0.16:2181,172.20.0.17:2181
在其他服务器上使用ZooKeeper客户端连接到相应的服务器,检查节点和值是否已同步。
0x05、注意事项
防火墙配置
确保每台服务器的防火墙配置允许ZooKeeper集群内部通信所需的端口。
日志管理
定期检查和清理ZooKeeper的日志文件,以避免磁盘空间不足导致的问题。
监控与报警
配置监控和报警系统,以便在ZooKeeper集群出现异常时能够及时发现并处理。
版本兼容性
确保集群中所有ZooKeeper服务器的版本一致,以避免版本不兼容导致的问题。
0x06、最后几句
ZooKeeper集群的搭建是一个复杂但重要的过程,它涉及到硬件准备、软件安装、网络配置、服务启动和验证等多个环节。通过上面的详细介绍,相信你应该能够掌握ZooKeeper集群搭建的基本步骤和注意事项,为构建稳定、高效的分布式系统打下坚实的基础。
同时,也建议在实际操作中不断积累经验,优化集群配置,提高系统的性能和可靠性。
相关文章:
ZK集群搭建:详细步骤与注意事项
在大数据和分布式系统日益重要的今天,ZooKeeper(简称ZK)作为一种分布式协调服务,扮演着举足轻重的角色。它主要用于管理大型分布式系统中的配置信息、命名、同步等。下面将详细介绍如何搭建一个ZooKeeper集群,帮助大家…...
如何将csdn文章导出为pdf
前言 在csdn上浏览文章的时候我发现有的文章支持pdf导出,但是有的文章不支持pdf导出,为了解决能将csdn上所有文章都能以pdf格式导出遂作此文。 正文 先上代码: (function(){use strict;var contentBox $("div.article_content")…...
【艾思科蓝】Imagen:重塑图像生成领域的革命性突破
【连续七届已快稳ei检索】第八届电子信息技术与计算机工程国际学术会议(EITCE 2024)_艾思科蓝_学术一站式服务平台 更多学术会议请看 学术会议-学术交流征稿-学术会议在线-艾思科蓝 目录 引言 一、Imagen模型的技术原理 1. 模型概述 2. 工作流程 …...
java类和对象(下): 封装 static成员 内部类
前言: 在前期的知识点中,我们学习了java中this函数的使用和相关的概念。这期我们将介绍封装的概念,以及常见内部类的使用,让我们开车吧!!!! 本期目录: 6. 封装 7. st…...
外包干了3周,技术退步太明显了。。。。。
先说一下自己的情况,大专生,21年通过校招进入武汉某软件公司,干了差不多3个星期的功能测试,那年国庆,感觉自己不能够在这样下去了,长时间呆在一个舒适的环境会让一个人堕落!而我才在一个外包企业干了3周的功…...
VIVO算法题——数位之积
记录算法究极无敌菜菜菜鸟的垃圾思维 题目: 现给定任意正整数 n,请寻找并输出最小的正整数 m(m>9),使得 m 的各位(个位、十位、百位 … …)之乘积等于n,若不存在则输出 -1。 菜鸟…...
OPC Router快速打通设备层与influxDB数据通讯
随着时代演化,数据量呈几何倍数增加的情况下出现了时序数据库。时序数据库是基于时间进行存储的数据库,每一条数据中都有一个时间戳,这种数据库特别适合存储那些随着时间变化的数据,通过一些工具处理后,能够分析出数据…...
鸿蒙开发 四十四 ArkTs BuilderParam传递UI(二)
子组件多个BuilderParam,必须通过参数的方式传入,如果界面中有多个界面需要传递,可以定义多个尾随闭包,如图: 在自定义组件中调用: 在使用时候调用是作为参数传递给自定义的组件,参数是界面&…...
同期数分析-留存率
目录 同期数分析 加载数据 单月实现 统计每个月的订单量 求2月份的订单量和用户数量 求2月之前的历史订单量 筛选出2023年2月的新增的用户数 计算2023年2月在后面的留存情况 完整的2023年2月份同期群结果 遍历合并和分析 引入月份列表 遍历 调整成留存率的形式 回…...
Java前后端交互:构建现代Web应用
在现代Web应用开发中,前后端分离是一种常见的架构模式。后端通常负责数据处理和业务逻辑,而前端则负责用户界面和用户体验。Java作为后端开发的强大语言,提供了多种方式与前端进行交互。本文将探讨Java后端与前端交互的几种主要方式ÿ…...
vue3中用axios请求怎么添加cookie
在 Vue 3 中使用 axios 发起请求时,可以通过配置 axios 的请求选项来携带 Cookies。具体来说,确保跨域请求时,设置 withCredentials: true,以便发送和接收 Cookies。 1. Axios 配置携带 Cookie 首先确保你在 axios 请求中设置了…...
informer学习笔记
一、informer讲解 infomer 要解决的三大问题: Attention计算的更快Decoder要一次性输出所有预测堆叠encoder也要更快 1. Attention 在长序列中,并非每一个位置的Attention都重要,对于每一个Q来说,只有一小部分的K与其有较强的…...
Elasticsearch介绍和使用
一、Elasticsearch 强大的搜索和分析能力: Elasticsearch 是一个基于 Lucene 的分布式搜索和分析引擎。它能够快速地对大量数据进行全文搜索、结构化搜索和复杂的数据分析操作。对于大型数据集,它可以高效地处理各种查询需求,包括关键词搜索…...
【Flutter】基础入门:代码基本结构
通过这个简单的 Flutter 示例程序,我们可以快速了解 Flutter 的代码结构,理解每个部分的作用。 import package:flutter/material.dart; void main() { runApp(const MyApp()); } class MyApp extends StatelessWidget { const MyApp({super.key}…...
如何进行数据库缩容 | OceanBase应用实践
作者:关炳文,爱可生 DBA 团队成员,负责数据库相关技术支持。 本文详细介绍了OceanBase V3.2版的集群中,面对数据文件缩容的场景的一套缩容方案,作为大家的参考。 缩容场景 某银行运行的一套采用1-1-1架构的OceanBase…...
机器学习和深度学习的差别
定义和基本原理 机器学习: 定义:机器学习是一种让计算机自动从数据中学习规律和模式的方法,无需明确编程。它通过构建数学模型,利用已知数据进行训练,然后对新的数据进行预测或决策。基本原理:机器学习算…...
RAG拉满-上下文embedding与大模型cache
无论怎么选择RAG的切分方案,仍然切分不准确。 最近,anthropics给出了补充上下文的embedding的方案,RAG有了新的进展和突破。 从最基础的向量查询,到上下文embedding,再到rerank的测试准确度都有了明显的改善…...
前端学习---(2)CSS基础
CSS 用来干什么? CSS 是用来指定文档如何展示给用户的一门语言——如网页的样式、布局、等等。 css语法: 选择器{ 属性名: 属性值; 属性名: 属性值; } h1 {color: red;font-size: 5em; }h1: 选择器 color: 属性 冒号之前是属性,冒号之后是值。 font-size…...
Pandas常用计算函数
目录 排序函数 nlargest函数 nsmallest函数 sort_values函数 df.sort_values Series.sort_values 聚合函数 corr函数-相关性 min函数-最小值 max函数-最大值 mean函数-平均值 sum函数-求和 count函数-统计非空数据 std函数-标准偏差 quantile函数-分位数 排序函…...
C++ | Leetcode C++题解之第473题火柴拼正方形
题目: 题解: class Solution { public:bool makesquare(vector<int>& matchsticks) {int totalLen accumulate(matchsticks.begin(), matchsticks.end(), 0);if (totalLen % 4 ! 0) {return false;}int len totalLen / 4, n matchsticks.s…...
5分钟上手抖音批量下载与高效管理工具:从单视频到整主页的完美解决方案
5分钟上手抖音批量下载与高效管理工具:从单视频到整主页的完美解决方案 【免费下载链接】douyin-downloader A practical Douyin downloader for both single-item and profile batch downloads, with progress display, retries, SQLite deduplication, and browse…...
从Doorbell到RoCE包:深度解析RDMA Tx数据流的硬件协同
1. 从门铃到数据包:RDMA发送流程全景图 想象一下你在一家高级餐厅点餐的场景:服务员(CPU)把你的订单(WQE)写在厨房门口的订单板(SQ环形缓冲区)上,然后按一下服务铃&…...
m4s-converter:让B站缓存视频真正为你所用的本地化工具
m4s-converter:让B站缓存视频真正为你所用的本地化工具 【免费下载链接】m4s-converter 一个跨平台小工具,将bilibili缓存的m4s格式音视频文件合并成mp4 项目地址: https://gitcode.com/gh_mirrors/m4/m4s-converter 一、问题象限:B站…...
从Hello World到生产部署:Agent开发完整教程
从Hello World到生产部署:Agent开发完整教程引言:为什么现在是学习Agent开发的黄金时代? 痛点引入:从“脚本化工具人”到“自主智能助手”的瓶颈 各位读者朋友们,我是老周,一个在互联网摸爬滚打了12年、从传…...
Pixel 7 实战:从源码编译到刷入 Android 15 UserDebug 的避坑指南
1. 环境准备:避开依赖地狱的三大陷阱 第一次给Pixel 7编译Android 15 UserDebug版本时,我踩遍了所有能踩的坑。最让人崩溃的不是代码编译失败,而是环境配置这种本该简单的步骤。先说硬件要求:至少16GB内存200GB SSD,我…...
为什么养鱼高手都换创牌无管件鱼缸?创牌无溢流区,到底强在哪?
创牌无管件鱼缸:它凭什么成为新一代鱼缸主流。创牌无管件无溢流区鱼缸 颜值更高 空间更大 过滤更强 更好打理 更安全。从“能用”升级到“好看、好用、高级”,一步到位。家有一缸,风生水起。干净、高级、好养的创牌无管件鱼缸࿰…...
突破VMware macOS限制:Auto-Unlocker的完整解决方案
突破VMware macOS限制:Auto-Unlocker的完整解决方案 【免费下载链接】auto-unlocker Unlocker for VMWare macOS 项目地址: https://gitcode.com/gh_mirrors/au/auto-unlocker 当你准备在VMware中创建macOS虚拟机时,却发现系统选择列表中根本没有…...
黑丝空姐-造相Z-Turbo极限测试:挑战复杂网络环境下的模型服务稳定性
黑丝空姐-造相Z-Turbo极限测试:挑战复杂网络环境下的模型服务稳定性 最近在折腾一个很有意思的项目,需要频繁调用一个部署在星图GPU平台上的AI图像生成服务,也就是大家可能听说过的“黑丝空姐-造相Z-Turbo”。这个模型生成特定风格人像的效果…...
Simulink电气仿真避坑指南:为什么我的可变RLC模型总报错?可能是你源选错了
Simulink电气仿真避坑指南:可变RLC模型报错的根源与解决方案 在电力电子和电机控制仿真领域,Simulink无疑是工程师们的首选工具。但许多用户在尝试搭建可变RLC元件时,总会遇到各种莫名其妙的报错和收敛问题。这往往不是因为你的电路设计有问…...
px、em、rem、vw、vh、clamp 怎么选?
整理了一套单位使用规范,新手可以直接套用,不用再纠结怎么选,高效又避坑: /* 1. 根字号:设置rem基准,避免浏览器差异 */ html { font-size: 16px; }/* 2. 字体:rem(全局统一…...

