当前位置: 首页 > java >正文

zookeeper-集群扩缩容

引言:

作为zk的日常运维人员,难免会遇到服务扩缩容的情况, 因此,我们需要掌握相关流程。

一. 3.5前的版本:

1. 扩容: 

原有节点

主机

myid

事务端口

选举端口

角色

l-zk-test1.xxx.com

1

2888

3888

follower

l-zk-test2.xxx.com

2

2888

3888

leader

l-zk-test3.xxx.com

3

2888

3888

follower

新加入两个节点:

l-zk-test4.xxx.com

4

2888

3888

l-zk-test5.xxx.com

5

2888

3888

a). 新节点添加配置:

tickTime=2000
initLimit=30
syncLimit=5
dataDir=/opt/zookeeper/data
dataLogDir=/opt/zookeeper/log
clientPort=2181
maxClientCnxns=1024
minSessionTimeout=4000
maxSessionTimeout=40000
autopurge.purgeInterval=24
autopurge.snapRetainCount=5
server.1=l-zk-test1.xxx.com:2888:3888
server.2=l-zk-test2.xxx.com:2888:3888
server.3=l-zk-test3.xxx.com:2888:3888
server.4=l-zk-test4.xxx.com:2888:3888
server.5=l-zk-test5.xxx.com:2888:3888
leaderServes=yes

b).  输入对应myid(echo 4 > /opt/zookeeper/data/myid)后,启动新节点(bin/zkServer.sh start)。

c).  逐台变更老节点配置,重启服务(bin/zkServer.sh restart)

2. 节点缩容:

  对于缩减,相当简单了, 只需要关闭需要下线的节点, 然后逐台变更线上节点配置后重启即可。 

3. 节点故障(替换):

    如果采用主机名方式(可以被其他节点解析), 绑定host或者dns 。 这种情况下,之间将node id和主机名改成故障节点的,启动就行。 

    如果采用ip的方式,那就只能走新增老的, 缩容故障 ,的方式了。 

二. 3.5.0之后的版本:

对于3.5.0版本以后,支持重配置动态变更配置。

zookeeper的重配置通过将部分配置移到一个动态文件(dynamicConfigFile)中来实现重配置, 如之前的静态配置为:

#vim zoo.cfg
tickTime=2000
initLimit=30
syncLimit=5
dataDir=/opt/zookeeper/data
dataLogDir=/opt/zookeeper/log
maxClientCnxns=1024
minSessionTimeout=4000
maxSessionTimeout=40000
autopurge.purgeInterval=24
autopurge.snapRetainCount=5
dynamicConfigFile=./dyn.cfg#dyn.cfg配置:
server.1=l-zk-test1.xxx.com:2888:3888:participant;2181
server.2=l-zk-test2.xxx.com:2888:3888:participant;2181
server.3=l-zk-test3.xxx.com:2888:3888:participant;2181

部署新节点后,我们通过以下指令就可变更节点:

reconfig -remove 2,3 -add server.4=l-zk-test4.xxx.com:2888:3888:participant;2181,5=l-zk-test5.xxx.com:2888:3888:participant;2181

不需要逐台变更配置,重启服务。 

-  --------------------------------------------------------------------------------------------------------------------------

                         深耕运维行业多年,擅长运维体系建设,方案落地。欢迎交流!

                                                     “V-x”: ywjw996

                                                     《 运维经纬 》

http://www.xdnf.cn/news/18961.html

相关文章:

  • 二次校验请求源 IP 是否在 WAF 官方 IP 段内” + “校验是否携带 WAF 专属 HTTP 头
  • 全域管控,一触可达:复合机器人远程监控方案重塑智能制造
  • volitale伪共享问题及解决方案
  • 高效管理远程连接!Remote Desktop Manager 全方位使用指南
  • 对接连连支付(四)-- 收款查询
  • 数据结构:单链表的应用(力扣算法题)第一章
  • 迅睿CMS自定义网站表单:HTML方式调用Select下拉选项数据指南
  • Winsock 操作指南
  • 宝塔面板零基础搭建 WordPress 个人博客与外贸网站 | 新手10分钟上手指南
  • vscode 调试 指定 python文件 运行路径
  • 嵌入式Linux自学不走弯路!670+讲课程!系统学习路线:入门+应用+ARM+驱动+移植+项目 (STM32MP157开发板)
  • Libvio访问异常排查指南
  • 《从有限元到深度学习:我的金属疲劳研究进阶之路》
  • Paimon——官网阅读:主键表
  • 【Kafka】项目整合使用案例
  • 解开 Ansible 任务复用谜题:过滤器用法、Include/Import 本质差异与任务文件价值详解
  • CPU 虚拟化之Cpu Models
  • 微算法科技(NASDAQ:MLGO)突破性FPGA仿真算法技术助力Grover搜索,显著提升量子计算仿真效率
  • 【LwIP源码学习7】ICMP部分源码分析
  • 【工具篇2】Gitee导入github repo作为持续的镜像站,自建 GitHub 镜像仓库详细步骤
  • Web转uni-app
  • 如何使用 Xshell 8 连接到一台 CentOS 7 电脑(服务器)
  • CellCharter | 入门了解
  • Linux 服务器故障全解析:常见问题及处理方法大全
  • imx6ull-驱动开发篇44——Linux I2C 驱动实验
  • PP工单状态JEST表
  • 浅聊达梦数据库物理热备的概念及原理
  • Ubuntu 切换 SOCKS5代理 和 HTTP 代理并下载 Hugging Face 模型
  • 三方相机问题分析八:【返帧异常导致性能卡顿】Snapchat后置使用特效预览出现卡顿
  • OpenTelemetry 在 Spring Boot 项目中的3种集成方式