猿创征文|ZooKeeper(伪)集群搭建

这篇具有很好参考价值的文章主要介绍了猿创征文|ZooKeeper(伪)集群搭建。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

前言:zookeeper作为一款分布式协调中间件,其重要性不言而喻,因此需要保证其高可用性。所以一般都会搭建zookeeper集群,今天叶秋带领大家在一台服务器上搭建伪集群。

zk伪集群模式,JAVA实战,java-zookeeper,zookeeper,大数据

目录

1、 搭建要求

2、 准备工作

3、 配置集群

 4 启动集群

 5 模拟集群异常


1、 搭建要求

真实的集群是需要部署在不同的服务器上的,但是在我们测试时同时启动很多个虚拟机内存会吃不消,所以我们通常会搭建 伪集群,也就是把所有的服务都搭建在一台虚拟机上,用 端口进行区分
我们这里要求搭建一个三个节点的Zookeeper集群(伪集群)。

2、 准备工作

1、首先必须安装好JDK先。

2、ZooKeeper压缩包上传到服务器,压缩包下载地址: Apache ZooKeeper

3、将Zookeeper解压 ,建立/usr/local/zookeeper-cluster目录,将解压后的Zookeeper复制到以下三个目录。

/usr/local/zookeeper-cluster/zookeeper-1
/usr/local/zookeeper-cluster/zookeeper-2
/usr/local/zookeeper-cluster/zookeeper-3

创建目录并将ZooKeeper压缩包解压到此目录

mkdir /usr/local/zookeeper-cluster

解压

tar -zxvf apache-zookeeper-3.7.0-bin.tar.gz -C /usr/local/zookeeper-cluster

zk伪集群模式,JAVA实战,java-zookeeper,zookeeper,大数据

 将解压后的Zookeeper复制到以下三个目录

cp -r apache-zookeeper-3.7.0-bin /usr/local/zookeeper-cluster/zookeeper-1
cp -r apache-zookeeper-3.7.0-bin /usr/local/zookeeper-cluster/zookeeper-2
cp -r apache-zookeeper-3.7.0-bin /usr/local/zookeeper-cluster/zookeeper-3

zk伪集群模式,JAVA实战,java-zookeeper,zookeeper,大数据

 4、创建data目录 ,并且将 conf下zoo_sample.cfg 文件改名为 zoo.cfg

mkdir /usr/local/zookeeper-cluster/zookeeper-1/data
mkdir /usr/local/zookeeper-cluster/zookeeper-2/data
mkdir /usr/local/zookeeper-cluster/zookeeper-3/data
mv /usr/local/zookeeper-cluster/zookeeper-1/conf/ zoo_sample.cfg /usr/local/zookeeper-cluster/zookeeper-1/conf/ zoo.cfg
mv /usr/local/zookeeper-cluster/zookeeper-2/conf/ zoo_sample.cfg /usr/local/zookeeper-cluster/zookeeper-2/conf/ zoo.cfg
mv /usr/local/zookeeper-cluster/zookeeper-3/conf/ zoo_sample.cfg /usr/local/zookeeper-cluster/zookeeper-3/conf/ zoo.cfg

5、 配置每一个Zookeeper 的dataDir 和 clientPort 分别为2182 2183 2184

修改/usr/local/zookeeper-cluster/zookeeper-1/conf/zoo.cfg

vim /usr/local/zookeeper-cluster/zookeeper-1/conf/zoo.cfg

内容:

clientPort=2182
dataDir=/usr/local/zookeeper-cluster/zookeeper-1/data

修改/usr/local/zookeeper-cluster/zookeeper-2/conf/zoo.cfg

vim /usr/local/zookeeper-cluster/zookeeper-2/conf/zoo.cfg

内容:

clientPort=2183
dataDir=/usr/local/zookeeper-cluster/zookeeper-2/data

修改/usr/local/zookeeper-cluster/zookeeper-3/conf/zoo.cfg

vim /usr/local/zookeeper-cluster/zookeeper-3/conf/zoo.cfg

内容:

clientPort=2184
dataDir=/usr/local/zookeeper-cluster/zookeeper-3/data

3、 配置集群

3.1、在每个zookeeper的 data 目录下创建一个 myid 文件,内容分别是1、2、3 。这个文件就是记录每个服务器的ID

echo 1 >/usr/local/zookeeper-cluster/zookeeper-1/data/myid
echo 2 >/usr/local/zookeeper-cluster/zookeeper-2/data/myid
echo 3 >/usr/local/zookeeper-cluster/zookeeper-3/data/myid

3.2、在每一个zookeeper 的 zoo.cfg配置客户端访问端口(clientPort)和集群服务器IP列表。集群服务器IP列表如下。

zookeeper-1

vim /usr/local/zookeeper-cluster/zookeeper-1/conf/zoo.cfg

内容:

server.1=192.168.58.150:2881:3881
server.2=192.168.58.150:2882:3882
server.3=192.168.58.150:2883:3883

zookeeper-2

vim /usr/local/zookeeper-cluster/zookeeper-2/conf/zoo.cfg

内容:

server.1=192.168.58.150:2881:3881
server.2=192.168.58.150:2882:3882
server.3=192.168.58.150:2883:3883

zookeeper-3

vim /usr/local/zookeeper-cluster/zookeeper-3/conf/zoo.cfg

内容:

server.1=192.168.58.150:2881:3881
server.2=192.168.58.150:2882:3882
server.3=192.168.58.150:2883:3883

zk伪集群模式,JAVA实战,java-zookeeper,zookeeper,大数据

 4 启动集群

启动集群就是分别启动每个实例。

/usr/local/zookeeper-cluster/zookeeper-1/bin/zkServer.sh start
/usr/local/zookeeper-cluster/zookeeper-2/bin/zkServer.sh start
/usr/local/zookeeper-cluster/zookeeper-3/bin/zkServer.sh start

zk伪集群模式,JAVA实战,java-zookeeper,zookeeper,大数据

启动后我们查询一下每个实例的运行状态

先查询第一个服务

/usr/local/zookeeper-cluster/zookeeper-1/bin/zkServer.sh start

zk伪集群模式,JAVA实战,java-zookeeper,zookeeper,大数据

Mode为follower表示是 跟随者(从)

再查询第二个服务Mod 为leader表示是领导者(主)

/usr/local/zookeeper-cluster/zookeeper-2/bin/zkServer.sh status

zk伪集群模式,JAVA实战,java-zookeeper,zookeeper,大数据

查询第三个为跟随者(从)

/usr/local/zookeeper-cluster/zookeeper-3/bin/ zkServer.sh status

zk伪集群模式,JAVA实战,java-zookeeper,zookeeper,大数据

 5 模拟集群异常

1、首先我们先测试如果是从服务器挂掉,会怎么样,把3号服务器停掉。

/usr/local/zookeeper-cluster/zookeeper-3/bin/ zkServer.sh stop

观察1号和2号

/usr/local/zookeeper-cluster/zookeeper-1/bin/ zkServer.sh status
/usr/local/zookeeper-cluster/zookeeper-2/bin/ zkServer.sh status

zk伪集群模式,JAVA实战,java-zookeeper,zookeeper,大数据

发现状态并没有变化。

由此得出结论,3个节点的集群,有一个从服务器挂掉,集群正常。

2、我们再把1号服务器(从服务器)也停掉。

/usr/local/zookeeper-cluster/zookeeper-1/bin/ zkServer.sh stop

查看2号(主服务器)的状态。

/usr/local/zookeeper-cluster/zookeeper-2/bin/ zkServer.sh status

发现已经停止运行了。

zk伪集群模式,JAVA实战,java-zookeeper,zookeeper,大数据

 由此得出结论,3个节点的集群,2个从服务器都挂掉,主服务器也无法运行。因为可运行的机器没有超过集群总数量的半数。

3、我们再次把1号服务器启动起来。

/usr/local/zookeeper-cluster/zookeeper-1/bin/zkServer.sh start

发现2号服务器又开始正常工作了。而且依然是领导者。

/usr/local/zookeeper-cluster/zookeeper-2/bin/zkServer.sh status

zk伪集群模式,JAVA实战,java-zookeeper,zookeeper,大数据

 4、我们把3号服务器也启动起来。

/usr/local/zookeeper-cluster/zookeeper-3/bin/ zkServer.sh start

把2号服务器停掉

/usr/local/zookeeper-cluster/zookeeper-2/bin/ zkServer.sh stop

停掉后观察1号和3号的状态。

/usr/local/zookeeper-cluster/zookeeper-1/bin/ zkServer.sh status
/usr/local/zookeeper-cluster/zookeeper-3/bin/ zkServer.sh status

zk伪集群模式,JAVA实战,java-zookeeper,zookeeper,大数据

 发现新的leader产生了~

由此我们得出结论,当集群中的主服务器挂了,集群中的其他服务器会自动进行选举状态,然后产生新得leader 。

5、我们再次测试,当我们把2号服务器重新启动起来启动后,会发生什么?

/usr/local/zookeeper-cluster/zookeeper-2/bin/ zkServer.sh start

2号服务器会再次成为新的领导吗?

/usr/local/zookeeper-cluster/zookeeper-2/bin/ zkServer.sh status
/usr/local/zookeeper-cluster/zookeeper-3/bin/ zkServer.sh status

zk伪集群模式,JAVA实战,java-zookeeper,zookeeper,大数据

 我们会发现,2号服务器启动后依然是跟随者(从服务器),3号服务器依然是领导者(主服务器),没有撼动3号服务器的领导地位。

由此我们得出结论,当领导者产生后,再次有新服务器加入集群,不会影响到现任领导者。

本期分享到此为止,关注博主不迷路叶秋学长带你上高速~~文章来源地址https://www.toymoban.com/news/detail-788706.html

到了这里,关于猿创征文|ZooKeeper(伪)集群搭建的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • kafka 集群 ZooKeeper 模式搭建

    Apache Kafka是一个开源分布式事件流平台,被数千家公司用于高性能数据管道、流分析、数据集成和关键任务应用程序 Kafka 官网:Apache Kafka 关于ZooKeeper的弃用 根据 Kafka官网信息,随着Apache Kafka 3.5版本的发布,Zookeeper现已被标记为已弃用。未来计划在Apache Kafka(4.0版)的下一

    2024年02月05日
    浏览(50)
  • 猿创征文|弃文从工,从小白到蚂蚁工程师,我的 Java 成长之路

    最近 CSDN 开展了猿创征文,希望博主写文章讲述自己在某个领域的技术成长历程。 之前也曾想找个机会写篇文章,记录下自己的成长历程。 因此,借着这个机会写下这篇文章。 在回顾自己的成长历程的同时,希望对一些同学的学习和工作也会有一些启发和帮助。 阅读本文,

    2024年02月16日
    浏览(46)
  • 猿创征文 | Shell编程【上篇】

    目录 1,Shell编程 1.1:简介 1.1.1:shell解释器 1.2:快速入门 1.2.1:编写脚本 1.2.2:执行shell脚本 1.3:shell变量 1.3.1:简介 1.3.2:使用变量 1.3.3:删除变量 1.3.4:只读变量  1.4:字符串 1.4.1:单引号 1.4.2:双引号  1.4.3:获取字符串长度   1.4.4:提取子字符串  1.5:传递参数 1

    2024年02月02日
    浏览(56)
  • 猿创征文 |【Linux】常用命令

    🍁 博客主页: 👉@不会压弯的小飞侠 ✨ 欢迎关注: 👉 点赞 👍 收藏 ⭐ 留言 ✒ ✨ 系列专栏: 👉Linux专栏 ✨ 欢迎加入社区: 👉不会压弯的小飞侠 ✨ 人生格言:知足上进,不负野心。 🔥 欢迎大佬指正,一起学习!一起加油! command [-options] [parameter] command:命令名 [-o

    2024年01月16日
    浏览(36)
  • 以太坊是什么?|猿创征文

    以太坊是一个可编程、可视化、更易用的区块链,它允许任何人编写智能合约和发行代币。 在以太坊(Ethereum)出现之前,各种区块链应用的功能非常有限,例如,比特币和其他加密货币都只是纯粹的数字货币。 以太坊(Ethereum)创始人Vitalik Buterin将以太坊(Ethereum)设想为开发人员

    2024年02月02日
    浏览(69)
  • 猿创征文| redis基本数据类型

    📃个人主页:不断前进的皮卡丘 🌞博客描述:梦想也许遥不可及,但重要的是追梦的过程,用博客记录自己的成长,记录自己一步一步向上攀登的印记 🔥个人专栏:微服务专栏 ✔️redis常见的操作命令:http://www.redis.cn/commands.html 命令 功能 keys * 查看当前库的所有key exists key 判断

    2023年04月08日
    浏览(40)
  • 猿创征文|【HTML】标签学习之路

    💖 目录 一、HTML语法规范 1.基本语法概述 2.标签关系 二、HTML基本结构标签 1.第一个HTML页面 2.HTML基本结构标签总结 1.基本语法概述 html是由尖括号包围的,列如: html 。 html标签通常是成对出现的,列如:html和/html,我们称为 双标签 。标签对里的第一个标签是开始标

    2024年01月16日
    浏览(40)
  • 猿创征文|【深度学习前沿应用】文本生成

    作者简介 :在校大学生一枚,C/C++领域新星创作者,华为云享专家,阿里云专家博主,腾云先锋(TDP)成员,云曦智划项目总负责人,全国高等学校计算机教学与产业实践资源建设专家委员会(TIPCC)志愿者,以及编程爱好者,期待和大家一起学习,一起进步~ . 博客主页 :

    2024年02月06日
    浏览(40)
  • 猿创征文|“云“创新展望:数据之浩瀚

    💗wei_shuo的个人主页 💫wei_shuo的学习社区 🌐Hello World ! AWS亚马逊云科技提供全球覆盖广泛、服务深入的云平台,全球数据中心提供超过 200 项功能齐全的服务 连续 11 年被 Gartner 评为\\\"全球云计算领导者\\\" ;2021 年全新 Gartner 魔力象限中被评为\\\"云基础设施与平台服务(Iaas Pa

    2023年04月24日
    浏览(85)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包