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
相关推荐
小猿姐19 小时前
MySQL Top 10 热点问题 AI 运维实战:从内核诊断到云原生运维
mysql·云原生·aiops
阿里云云原生2 天前
深入内核:拆解 OpenTelemetry eBPF 探针如何优雅地“透视”多语言微服务?
云原生
JLWcai202510092 天前
铸造领域树脂砂轮|金利威多场景解决方案,20 + 配方覆盖全需求
mongodb·zookeeper·eureka·spark·rabbitmq·memcached·storm
java_cj2 天前
深入kube-apiserver认证机制:从Bearer Token到mTLS的完整认证链解析
linux·运维·服务器·云原生·容器·kubernetes
风吹夏回2 天前
RabbitMQ 核心术语 + Python pika 方法完整讲解
分布式·python·rabbitmq
风吹夏回2 天前
RabbitMQ 三种模式入门:HelloWorld、WorkQueue、PubSub
分布式·rabbitmq·ruby
霸道流氓气质2 天前
分布式追踪与 RequestId 传播完全指南
分布式
cheems95272 天前
[RabbitMQ高级特性] 消息确认机制:从 Ready / Unacked 到 basicAck、basicReject、basicNack 的底层拆解
分布式·rabbitmq·ruby
互联网推荐官2 天前
上海软件定制开发公司推荐:从PaaS工程化路径看D-coding的技术取舍
云原生·云计算·paas·软件开发·开发经验·上海
sbjdhjd2 天前
从零搭建企业级 CI/CD(下):Jenkins+GitLab+Harbor 全链路实战指南
git·servlet·ci/cd·云原生·云计算·gitlab·jenkins