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
相关推荐
霖霖总总5 小时前
[Redis小技巧32]Redis分布式锁的至暗时刻:从原理演进到时钟跳跃的终极博弈
数据库·redis·分布式
ZC跨境爬虫5 小时前
Scrapy分布式爬虫(单机模拟多节点):豆瓣Top250项目设置与数据流全解析
分布式·爬虫·python·scrapy
ZC跨境爬虫8 小时前
通俗易懂讲解分布式爬虫基础概念(附Scrapy-Redis实操教程)
redis·分布式·爬虫·python·scrapy
Hachi被抢先注册了11 小时前
Docker学习记录
java·云原生·eureka
阿里云云原生12 小时前
安全养虾实践:当 AI 管家遇到线上预警,我的提效破局之路
云原生
阿里云云原生13 小时前
相约 GenAICon 北京站:聊聊从环境工程出发,如何“简化”多源实时上下文?
云原生
数字化顾问15 小时前
(88页PPT)DG1092D1S4培训课件EASGERP总体架构基础(附下载方式)
微服务·云原生·架构
x10n916 小时前
基于提示词驱动的Function Call实现K8s Pod智能诊断
ai·云原生·容器·kubernetes
阿里云云原生16 小时前
当运维遇见本体论:Umodel 打造 IT 世界的统一认知地图
云原生
小红的布丁16 小时前
雪花算法:高并发场景下的分布式唯一ID生成方案解析
分布式