Zookeeper版本升级

前言

bash 复制代码
因Apache ZooKeeper 3.9.1之前、3.8.3之前、3.7.2之前版本存在安全漏洞,所以需要将原来的3.5.9版本升级到3.9.3版本。为了保险起见,需要进行短暂的停服,对Zookeeper数据目录(version-2)进行备份。

一、安装新版本Zookeeper

1、准备安装包

bash 复制代码
#下载安装包,可能会因为网站限制wget或者curl的命令会报403,需要下载本地再上传服务器
wget https://mirrors.tuna.tsinghua.edu.cn/apache/zookeeper/zookeeper-3.9.3/apache-zookeeper-3.9.3-bin.tar.gz --no-check-certificate
#解压并重命名
tar xvf apache-zookeeper-3.9.3-bin.tar.gz && mv apache-zookeeper-3.9.3-bin zookeeper-3.9.3 && mv zookeeper-3.9.3 /data

2、创建数据目录,修改配置文件(注意:配置文件不需要改路径!!!)

bash 复制代码
#进入到zookeeper,创建data文件夹,作为zk存放数据的目录
cd /data/zookeeper-3.9.3 && mkdir data
#复制配置文件
cd conf && cp zoo_sample.cfg zoo.cfg
#修改配置文件
vim zoo.cfg   
tickTime=2000                 #心跳基本时间单位,毫秒级,ZK基本上所有的时间都是这个时间的整数倍 
initLimit=10                  #tickTime的个数,表示在leader选举结束后,followers与leader同步需要的时间,如果followers比较多或者说leader的数据灰常多时,同步时间相应可能会增加,那么这个值也需要相应增加。当然,这个值也是follower和observer在开始同步leader的数据时的最大等待时间(setSoTimeout) 
syncLimit=5                   #tickTime的个数,这时间容易和上面的时间混淆,它也表示follower和observer与leader交互时的最大等待时间,只不过是在与leader同步完毕之后,进入正常请求转发或ping等消息交互时的超时时间
dataDir=/data/zookeeper/data  #内存数据库快照存放地址,如果没有指定事务日志存放地址(dataLogDir),默认也是存放在这个路径下,建议两个地址分开存放到不同的设备上。
clientPort=2181               #配置ZK监听客户端连接的端口
admin.serverPort=8520         #AdminServer是一个内置的Jetty服务。默认的服务启动在8080端口,这里将其改为8520端口。

3、脚本启动、停止zookeeper(注意:先不要启动!!!)

bash 复制代码
#启动
cd /data/zookeeper-3.9.3/bin
sh zkServer.sh start
sh zkServer.sh status
#停止
sh zkServer.sh stop
#打开客户端
sh zkCli.sh

4、设置开机自启动,用service管理(注意:配置不需要改,先不要启动!!!)

bash 复制代码
#设置开机自启动
#进入/etc/init.d目录
cd /etc/init.d
#创建zookeeper文件(JAVA_HOME需要确定一下)

vim zookeeper
#!/bin/bash
#chkconfig:2345 20 90
#description:zookeeper
#processname:zookeeper
ZK_PATH=/data/zookeeper
export JAVA_HOME=/usr/java/jdk1.8.0_212-amd64
case $1 in
         start) sh  $ZK_PATH/bin/zkServer.sh start;;
         stop)  sh  $ZK_PATH/bin/zkServer.sh stop;;
         status) sh  $ZK_PATH/bin/zkServer.sh status;;
         restart) sh $ZK_PATH/bin/zkServer.sh restart;;
         *)  echo "require start|stop|status|restart"  ;;
esac

#给zookeeper添加执行权限
chmod 755 zookeeper
#将其注册为服务
chkconfig --add zookeeper
#用service启动
service zookeeper start
#查看zookeeper状态
service zookeeper status

二、迁移旧版Zookeeper数据

1、停服

bash 复制代码
# 停Nginx服务,停Java服务,停Zookeeper服务,前面服务就不赘述了
# 停zookeeper服务
service zookeeper stop
#查看zookeeper状态
service zookeeper status

2、复制旧版Zookeeper数据目录到新版

bash 复制代码
#将新版Zookeeper的version-2备份,并清空(执行rm -f命令要看好再操作)
mv /data/zookeeper-3.9.3/data/version-2  /data/zookeeper-3.9.3/data/version-2-$(date +"%Y%m%d-%H%M%S")
rm -f /data/zookeeper-3.9.3/data/version-2/*
#复制旧版version-2到新版data目录下
cp -a /data/zookeeper/data/version-2 /data/zookeeper-3.9.3/data/version-2

3、重命名旧版Zookeeper安装目录

bash 复制代码
mv /data/zookeeper /data/zookeeper-$(date +"%Y%m%d-%H%M%S")

4、创建软连接

bash 复制代码
ln -sv /data/zookeeper-3.9.3 /data/zookeeper

三、启动新版Zookeeper

bash 复制代码
#用service启动
service zookeeper start
#查看zookeeper状态
service zookeeper status

#升级完成!!!可以通过可视化工具连接Zookeeper进行验证,推荐可视化工具PrettyZoo
#下载地址:https://github.com/vran-dev/PrettyZoo/releases
相关推荐
学博成2 小时前
备考“系统架构设计师”
微服务·云原生·架构·架构设计师
Bruce20489982 小时前
Go 云原生实战:K8s Operator 开发与服务网格(Istio)落地
云原生·golang·kubernetes
Lucas6492 小时前
K8S-从理论到实战
云原生·容器·kubernetes
真上帝的左手2 小时前
12. 消息队列-RabbitMQ-高可用队列详解
分布式·rabbitmq·mq
云川之下3 小时前
【k8s】user 用户身份确定流程
云原生·容器·kubernetes
十月南城3 小时前
结语与展望——云原生、Serverless、AIOps的趋势与融合
云原生·serverless
帮我吧智能服务平台3 小时前
深度拆解:“帮我吧”如何实现PaaS化架构下的“随需而建”
云原生·架构·paas
Bruce20489984 小时前
2026 云原生安全:Rust 编写微服务网关与零信任实践
安全·云原生·rust
步步为营DotNet4 小时前
探索.NET 11 中 Native AOT 在云原生性能优化的极致应用
云原生·性能优化