【zookeeper】集群配置

ops/2024/10/21 16:50:37/

zookeeper_0">zookeeper

数据结构

  • zookeeper数据模型结构,就和Linux的文件系统类型,看起来是一颗树,每个节点称为一个znode.
  • 每一个Znode默认的存储1MB的数据,每个Znode都有唯一标识,可以通过命令显示节点的信息
  • 每当节点有数据变化,节点的版本号都会累加
  • 删除或者修改过时的节点,版本号不匹配的话就会报错
  • 每个zk存储的数量不易过大,一般为几KB
  • 每一个znode可以设置acl,进行用户权限的访问,不同的节点数据

特点

  • 暂时的\临时(Ephemera):当客户端和服务端断开连接后,所创建的Znode(节点)会自动删除
  • 持久(Persistent):当客户端和服务端断开连接的时候,所创建的Znode不会自动删除

zookeeper和Redis一样,也是c/s结构(分成客户端和服务端)

监听器

在上面我们知道了zookeeper的数据结构了,但是zookeeper才能做那么多的事情

常见的监听场景有以下两项:

  • 简历Znode节点的数据变化
  • 监听子节点的增减变化/app1节点以及子节点是否增减

在这里插入图片描述

zookeeper_30">安装zookeeper集群

环境准备
IP地址主机名myid
192.168.116.136master1
192.168.116.137node12
192.168.116.138node23
  1. 更改主机名
# 在第一个虚拟机
hostnamectl set-hostname master
# 在第二个虚拟机
hostnamectl set-hostname node1
# 在第三个虚拟机
hostnamectl set-hostname node2
  1. 映射
vi /etc/hosts192.168.116.136 master
192.168.116.137 node1
192.168.116.138 node2
  1. 修改网络配置(对每一个机器都进行修改,避免IP地址变化)
vim /etc/sysconfig/network-scripts/ifcfg-ens33BOOTPROTO="static"IPADDR=192.168.116.136
NETMASK=255.255.255.0
GATEWAY=192.168.116.2
DNS1=8.8.8.8
DNS2=114.114.114.114

1.安装jdk

上传jdk 的安装包到系统中

  1. 解压jdk安装包
tar -zxvf jdk-8u202-Linuxx64.tar.gz 
  1. 更改解压后的文件名
mv jdk1.8.0_202 jdk
  1. 更改环境变量
vi /etc/profile# 在文件的最后加入
export JAVA_HOME=/software/jdk
export PATH=$PATH:$JAVA_HOME/bin
  1. 重新加载环境变量
source /etc/proflie
  1. jdk是否配置成功
java -version

zookeeper_115">配置zookeeper

  1. 安转包上传到服务器
  2. 解压安装包
tar -xvf apache-zookeeper-3.5.6-bin.tar.gz 
  1. 创建文件夹,用于存储zk数据
cd /software/zookeeper/
mkdir zkdata
  1. 创建myid文件
cd zkdata
echo '1' > myid
  1. 修改配置文件
vim software/zookeeper/conf/zoo.cfgdataDir=/software/zookeeper/zkdata/server.1=192.168.116.136:2888:3888
server.2=192.168.116.137:2888:3888
server.3=192.168.116.138:2888:3888
  1. 配置环境变量
vim /etc/profileexport ZK_HOME=/software/zookeeper
export PATH=$PATH:$ZK_HOME/bin
  1. 分发文件
# 生成公钥(一直回车确认就可以)
ssh-keygen# 将免密配置到各个节点
ssh-copy-id master
ssh-copy-id node1
ssh-copy-id node2# 分发环境变量
scp /etc/profile node1:/etc/profile
scp /etc/profile node2:/etc/profile# 向node2发送配置程序
scp -r /software root@node1:$PWD
# 向node3发送配置程序
scp -r /software root@node2:$PWD
  1. 开始在每个虚拟机都启动zookeeper
# 启动
zkServer.sh start
# 查看状态
zkServer.sh statusmaster:
ZooKeeper JMX enabled by default
Using config: /software/zookeeper/bin/../conf/zoo.cfg
Client port found: 2181. Client address: localhost.
Mode: followernode1:
ZooKeeper JMX enabled by default
Using config: /software/zookeeper/bin/../conf/zoo.cfg
Client port found: 2181. Client address: localhost.
Mode: leadernode2:
zkServer.sh status
ZooKeeper JMX enabled by default
Using config: /software/zookeeper/bin/../conf/zoo.cfg
Client port found: 2181. Client address: localhost.
Mode: follower

战斗结束,个人笔记,有错误,望指正,在此谢过


http://www.ppmy.cn/ops/127318.html

相关文章

修改pq_default.ini禁用降噪,解决S905X3电视盒硬解视频画质模糊、严重涂抹得像油画、水彩画的问题

笔者使用一台处理器芯片为 S905X3 的电视盒将近一年,性能比之前的 RK3328 的盒子有所提升,但我对它视频解码方面感到越来越不爽,该盒子的硬解视频总是开启美颜降噪和锐化,导致硬解视频的画质模糊,细节都被磨平&#xf…

SpringBoot智能推荐:健康生活新趋势

摘要 随着信息技术在管理上越来越深入而广泛的应用,管理信息系统的实施在技术上已逐步成熟。本文介绍了基于智能推荐的卫生健康系统的开发全过程。通过分析基于智能推荐的卫生健康系统管理的不足,创建了一个计算机管理基于智能推荐的卫生健康系统的方案。…

DAY52WEB 攻防-XSS 跨站反射型存储型DOM 型标签闭合输入输出JS 代码解析

#知识点: 1、XSS跨站-输入输出-原理&分类&闭合 2、XSS跨站-分类测试-反射&存储&DOM 演示案例: ➢XSS跨站-输入输出-原理&分类&闭合 ➢XSS跨站-分类测试-反射&存储&DOM #XSS跨站-输入输出-原理&分类&闭合 漏…

CICD持续集成交付与持续交付

一 CICD是什么 CI/CD 是指持续集成(Continuous Integration)和持续部署(Continuous Deployment)或持续交付(Continuous Delivery) 1.1 持续集成(Continuous Integration) 持续集成…

Taro构建的H5页面路由切换返回上一页存在白屏页面过渡

目录 项目背景:Taro与Hybrid开发问题描述:白屏现象可能的原因包括: 解决方案解决后的效果图 其他优化方案可参考: 项目背景:Taro与Hybrid开发 项目使用Taro框架同时开发微信小程序和H5页面,其中H5页面被嵌…

Linux安装、启动Nginx

前言: Nginx 安装 需要 gcc g perl openssl pcre zlib 依赖,没有安装的话需自行安装 一 下载安装Nginx Nginx下载地址如下 下载地址 网盘分享地址 将安装包解压至/usr/local tar -zxvf nginx-1.24.0.tar.gz -C /usr/local/进入/usr/local/nginx-1.2…

【Postman】如何导出导入数据文件?Postman链接分享?

方式一:postman分享链接 1.1 导出 1.2 导入 1.3 导入完成后删除分享的链接 方式二:postman导出导入json 2.1 导出 2.2 post导入json数据

基于BERT的语义分析实现(论文复现)

基于BERT的语义分析实现(论文复现) 本文所涉及所有资源均在传知代码平台可获取 文章目录 基于BERT的语义分析实现(论文复现)概述语义分类文本分类情感分类实现原理核心逻辑test_demo.py实现方式&演示效果训练阶段测试阶段概述 在之前的文章中,我们介绍了BERT模型。BER…