【分布式技术】中间件-zookeeper安装配置

文章目录

    • 安装部署
      • 1. 安装ZooKeeper
      • 2. 配置ZooKeeper
      • 3. 启动ZooKeeper服务器
      • 4. 使用ZooKeeper命令行客户端
      • 5. 使用ZooKeeper的四个基本操作
      • 6. ZooKeeper集群模式
      • 7. 安全和权限
      • 8. 监控和日志
    • 相关文献

安装部署

在Linux环境中操作ZooKeeper通常涉及以下几个方面:

1. 安装ZooKeeper

在Linux上安装ZooKeeper,你可以从Apache ZooKeeper的官方网站下载二进制包或使用包管理器安装。以下是使用二进制包安装的步骤:

# 下载ZooKeeper
wget https://downloads.apache.org/zookeeper/zookeeper-3.8.0/apache-zookeeper-3.8.0-bin.tar.gz# 解压ZooKeeper
tar -xzf apache-zookeeper-3.8.0-bin.tar.gz# 进入ZooKeeper目录
cd apache-zookeeper-3.8.0-bin# 创建ZooKeeper的数据目录
mkdir data

2. 配置ZooKeeper

编辑conf/zoo.cfg文件,配置ZooKeeper服务器:

tickTime=2000
dataDir=/home/zookeeper/apache-zookeeper-3.8.0-bin/data
clientPort=2181
initLimit=5
syncLimit=2# 配置集群模式(单机模式不需要配置)
server.1=127.0.0.1:2886:3886
server.2=127.0.0.1:2888:3888

3. 启动ZooKeeper服务器

在ZooKeeper的bin目录下,使用以下命令启动服务器:

# 启动ZooKeeper
./zkServer.sh start# 查看状态
./zkServer.sh status# 停止ZooKeeper
./zkServer.sh stop

4. 使用ZooKeeper命令行客户端

ZooKeeper提供了一个命令行客户端zkCli.sh,用于与ZooKeeper服务器交互:

# 启动ZooKeeper命令行客户端
./zkCli.sh# 连接到ZooKeeper服务器
[zk: localhost:2181(CONNECTED) 0] connect host:port# 创建一个节点
create /test data# 获取节点数据
get /test# 列出子节点
ls /# 删除节点
delete /test# 退出客户端
quit

5. 使用ZooKeeper的四个基本操作

  • 创建节点(Create)
    create /path data
    
  • 读取节点(Read)
    get /path
    
  • 更新节点(Update)
    set /path data
    
  • 删除节点(Delete)
    delete /path
    

6. ZooKeeper集群模式

如果需要部署ZooKeeper集群,需要在zoo.cfg中配置多个服务器,并在每台服务器上设置唯一的myid文件:

echo "1" > data/myid

然后,在所有服务器上启动ZooKeeper。

7. 安全和权限

ZooKeeper支持ACL(访问控制列表),可以通过设置权限来控制对节点的访问:

# 设置权限
setAcl /path acl

8. 监控和日志

监控ZooKeeper的性能和查看日志对于维护ZooKeeper集群非常重要。ZooKeeper的日志文件通常位于dataLogDir指定的目录下。

通过这些基本操作,你可以在Linux环境中管理和使用ZooKeeper。对于更高级的使用场景,如分布式锁或领导者选举,你可能需要编写更复杂的客户端程序来实现。

相关文献

【分布式技术】中间件-分布式协调服务zookeeper

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/57719.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

同城分类信息网站源码系统 PHP+MySQL组合开发 带完整的安装代码包以及搭建部署教程

系统概述 该系统采用PHP作为后端开发语言,MySQL作为数据库管理系统。PHP是一种广泛使用的开源脚本语言,特别适合于Web开发,具有跨平台、易于学习、性能稳定等优点。MySQL则是一款轻量级的关系型数据库管理系统,具有体积小、速度快…

DHorse v1.6.0 发布,基于 k8s 的发布平台

版本说明 新增特性 支持Codeup(阿里云云效)代码仓库;支持环境的自动部署; 优化特性 管理员角色部署环境部需要审批;优化页面展示; 升级指南 升级指南 DHorse介绍 DHorse是一个轻量级、简单易用的云…

微服务网关Zuul

一、Zuul简介 Zuul是Netflix开源的微服务网关,包含对请求的路由和过滤两个主要功能。 1)路由功能:负责将外部请求转发到具体的微服务实例上,是实现外部访问统一入口的基础。 2)过滤功能:负责对请求的过程…

车型TCU\EMS刷写详细分析

概述车型TCU(Transmission Control Unit,自动变速器控制单元)和EMS(Engine Management System,发动机管理系统)刷写的关键信息。 一、TCU刷写分析 1. TCU概述 TCU是汽车自动变速器的核心控制单元&#x…

总结性标题:高效导入文本数据,探索 MySQL 与 Java 的最佳实践

全文目录: 开篇语📝 前言🏷️ 摘要📚 简介🔍 概述🚀 核心源码解读📖 核心逻辑 🛠️ 案例分析🌍 应用场景演示👍 优缺点分析优点缺点 🔧 类代码方法…

cesium相机(camera)控制

camera基础属性: Cesium 中的相机通过 viewer.camera 来获取和操作。 position:相机的位置,用 Cartesian3 坐标表示,表示的是相机在世界坐标系中的绝对位置。 viewer.camera.position Cesium.Cartesian3.fromDegrees(longitude, latitude, height);dir…

uniapp实现多文件下载,保存到本地

概览 uniapp实现多文件下载,保存到本地,因为使用的是uni.downloadFile 实现文件的下载,每次只能下载一个,需要下载多个文件,并保存到本地,并把保存的地址存储到对应的数据组中,并实现进度条显示…

crc, md5 和 sha的区别

效率不同: 直接看代码 import zlib import hashlib import timewith open(rD:\data., rb) as f:x f.read()s time.time() for i in range(100000):d zlib.crc32(x) print(time.time() - s)s time.time() for i in range(100000):m hashlib.md5()m.update(x)d m.hexdige…

学习webservice的心得

一.首先确定数据库中字段,编写相应的实体类,如果使用的是若依框架,则选择代码生成。 二.将生成的或者自己编写的实体类,mapper,service,serviceImpl,controller,(如果是xml文件写的sql,还需要编…

【CSS】纯CSS Loading动画组件

<template><div class"ai-loader-box"><!-- AI loader --><div class"ai-loader"><div class"text"><p>AI智能分析中....</p></div><div class"horizontal"><div class&quo…

idea项目搭建的四种方式: 一(以idea2017为例)

目录 1. 普通java项目 2. 普通JavaWEB项目 3. maven的JavaWEB项目 4. maven的java项目 1. 普通java项目 ①点击“Create New Project”&#xff1b; ②选择“Java”&#xff0c;选择自己安装的jdk&#xff0c;点击“Next”&#xff1b; ③填好项目名称和路径&#xff1b;…

记录一个docker volume映射目录创建文件报错问题

最近用docker-compse做中间件部署。 发现使用volume映射目录后&#xff0c;初始化时创建文件报错导致容器启动失败问题。 提示是没有访问权限。 如下&#xff1a; mariadb 10:07:26.86 INFO > mariadb 10:07:26.86 INFO > Welcome to the Bitnami mariadb contain…

CORS预检请求配置流程图 srpingboot和uniapp

首先要会判断预检请求 还是简单请求 简单请求 预检请求 #mermaid-svg-1R9nYRa7P9Pll4AK {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-1R9nYRa7P9Pll4AK .error-icon{fill:#552222;}#mermaid-svg-1R9nYRa7P9Pll4…

关于测试用例的写法

最近公司有个新项目&#xff0c;需要写测试用例&#xff0c;表单项有点多&#xff0c;一个表单都有40个字段左右&#xff0c;若写用例得400条左右&#xff0c;大部分都是重复的项&#xff0c;在此写个小程序&#xff0c;批量生成测试用例 需要注意的是本程序只使用于表单内容 模…

基于ssm+vue的购物商场的设计与实现

博主介绍&#xff1a;专注于Java&#xff08;springboot ssm 等开发框架&#xff09; vue .net php phython node.js uniapp 微信小程序 等诸多技术领域和毕业项目实战、企业信息化系统建设&#xff0c;从业十五余年开发设计教学工作 ☆☆☆ 精彩专栏推荐订阅☆☆☆☆☆不…

JavaScript 的 axios 实现文件下载功能

用 JavaScript 的 axios 实现文件下载功能&#xff0c;咱们要分几个步骤来搞定它&#xff01;最主要的部分是处理 二进制数据&#xff0c;可以生成一个进度检测&#xff0c;然后把它保存为文件。 文件名的获取二进制数据获取创建下载链接 const axios require(axios);const g…

【视频生成大模型】 视频生成大模型 THUDM/CogVideoX-2b

【视频生成大模型】 视频生成大模型 THUDM/CogVideoX-2b CogVideoX-2b 模型介绍发布时间模型测试生成的demo视频生成视频限制 运行环境安装运行模型下载开源协议参考 CogVideoX-2b 模型介绍 CogVideoX是 清影 同源的开源版本视频生成模型。 基础信息&#xff1a; 发布时间 2…

【【自动驾驶】车辆运动学模型】

【自动驾驶】车辆运动学模型 1. 引言2. 以车辆重心为中心的单车模型2.1 模型介绍2.2 滑移角 β \beta β 的推导2.2 航向角 ψ \psi ψ推导过程&#xff1a;2.3 滑移角 β \beta β2.3 Python代码实现2.4 C代码实现 3. 前轮驱动的单车模型3.1 模型介绍3.3 Python代码实现3.4 …

【功能安全】 独立于环境的安全要素SEooC

目录 01 SEooC定义 02 SEooC开发步骤 03 SEooC开发示例 04 SEooC问答 01 SEooC定义 缩写: SEooC:Safety Element out of Context独立于环境的安全要素 SEooC出处:GB/T34590.10—2022,第9章节 SEooC与相关项什么关系? SEooC可以是系统、系统组合、子系统、软件组件、…

【软件设计】常用设计模式--代理模式

文章目录 代理模式&#xff08;Proxy Pattern&#xff09;1. 概念2. 模式结构3. UML 类图4.实现方式C# 示例步骤1&#xff1a;定义主题接口步骤2&#xff1a;实现真实主题步骤3&#xff1a;实现代理类步骤4&#xff1a;客户端使用代理模式输出结果&#xff1a; Java 示例步骤1&…