Apach Ozone部署
前言
最近由于工作需要,要部署一套ozone。我自己对hadoop这套体系不是很熟悉,所以过程磕磕碰碰,好不容易勉强搭起来,所以记录一下部署方式
准备
三台主机,主机均已安装jdk、hdfs,相关的安装配置就不另外写了,网上很多教程。
本次安装部署版本为当前最新的ozone-1.3.0版
部署步骤
1、ozone官网下载安装包,ozone有多种安装方式(docker、二进制包、源码编译等)。这里用二进制包安装方式。下载地址:Apache Ozone。这里下载了1.3.0版。ozone-1.3.0.tar.gz
2、上传到服务器:
部分服务器没有szrz命令的,可以通过scp命令进行复制:
scp ozone-1.3.0.tar.gz username@remote_ip:~/ 解压:
tar zxvf ozone-1.3.0.tar.gz 3、生成配置文件
进入ozone目录
cd ozone 生成配置文件ozone-site.xml到etc/hadoop目录下
bin/ozone genconf etc/hadoop PS:如果生成配置文件前/etc/hadoop已存在ozone-site.xml,则先行删除。
4、规划各机器职责并完成配置文件的配置
规划ozone的Ozone Manager(OM)、Storage Container Manager(SCM)、Datanodes服务分别部署在哪些机器上。假设在a主机上启动OM、SCM服务,a、b、c上启动Datanodes服务。
在a、b、c主机上创建元数据存储文件夹
mkdir -p 自定义目录/ozonedata/meta 在a、b、c主机上分别创建数据存储文件夹
mkdir -p 自定义目录/ozonedata/data 配置etc/hadoop/ozone-site.xml
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<configuration><property><name>ozone.om.address</name><value>A主机ip</value><tag>OM, REQUIRED</tag></property><property><name>ozone.metadata.dirs</name><value>用户目录/ozonedata/meta</value><tag>OZONE, OM, SCM, CONTAINER, STORAGE, REQUIRED</tag></property><property><name>ozone.scm.client.address</name><value>A主机ip:9860</value><tag>OZONE, SCM, REQUIRED</tag></property><property><name>ozone.scm.names</name><value>A主机ip</value><tag>OZONE, REQUIRED</tag></property><property><name>ozone.scm.datanode.id.dir</name><value>用户目录/ozonedata/data</value></property><property><name>ozone.enabled</name><value>true</value></property><property><name>ozone.scm.datanode.id</name><value>用户目录/ozonedata/data/datanode.id</value></property>
</configuration> 配置etc/hadoop/core-site.xml
<configuration><property><name>fs.AbstractFileSystem.o3fs.impl</name><value>org.apache.hadoop.fs.ozone.OzFs</value></property><property><name>fs.defaultFS</name><value>o3fs://bucket.volume</value></property>
</configuration> 在A主机上启动OM、SCM和datanode
到ozone-1.3.0/bin目录下执行
./ozone --daemon start scm
./ozone --daemon start om
./ozone --daemon start datanode 在B、C主机下启动datanode
到ozone-1.3.0/bin目录下执行
./ozone --daemon start datanode 可以到ozone-1.3.0/logs目录下查看是否启动成功。由于datanode使用ratis协议,所以至少要部署3个节点,否则写入数据的时候会报:
INTERNAL_ERROR Allocated 0 blocks. Requested 1 blocks 验证
尝试创建一个卷(volume):
./ozone sh volume create volume 在卷下面创建一个桶(bucket):
./ozone sh bucket create volume/bucket 在桶下面往key写入一个文件:
./ozone sh key put volume/bucket/mykey1 用户目录/ozone-1.3.0/etc/hadoop/ozone-site.xml 之后通过查看桶下面的key,以及myKey1下的文件内容,验证是否写入成功
./ozone sh key ls volume/bucket
./ozone sh key cat volume/bucket/mykey1 小结
本文主要介绍了ozone的基本部署。ozone还有很多高可用、安全性等等的配置值得深入研究,因为笔者还没有需要使用,所以暂时没有去研究,有兴趣的读者也可以参考官网文档:https://ozone.apache.org/docs/1.3.0/zh/index.html
相关文章:
Apach Ozone部署
前言 最近由于工作需要,要部署一套ozone。我自己对hadoop这套体系不是很熟悉,所以过程磕磕碰碰,好不容易勉强搭起来,所以记录一下部署方式 准备 三台主机,主机均已安装jdk、hdfs,相关的安装配置就不另外写…...
【nlp】3.2 Transformer论文复现:1. 输入部分(文本嵌入层和位置编码器)
Transformer论文复现:输入部分(文本嵌入层和位置编码器) 1 输入复现1.1 文本嵌入层1.1.1 文本嵌入层的作用1.1.2 文本嵌入层的代码实现1.1.3 文本嵌入层中的注意事项1.2 位置编码器1.2.1 位置编码器的作用1.2.2 位置编码器的代码实现1.2.3 位置编码器中的注意事项1 输入复现…...
自动化部署 / 扩容openGauss —— Ansible for openGauss
前言 大家好,今天我们为大家推荐一套基于 Ansible 开发的,自动化部署及扩容 openGauss 的脚本工具:Ansible for openGauss(以下简称 AFO)。 通过AFO,我们只需简单修改一些配置文件,即可快速部署…...
Go 实现网络代理
使用 Go 语言开发网络代理服务可以通过以下步骤完成。这里,我们将使用 golang.org/x/net/proxy 包来创建一个简单的 SOCKS5 代理服务作为示例。 步骤 1. 安装 golang.org/x/net/proxy 包 使用以下命令安装 golang.org/x/net 包,该包包含 proxy 子包&am…...
Redis报错:JedisConnectionException: Could not get a resource from the pool
1、问题描述: redis.clients.jedis.exceptions.JedisConnectionException: Could not get a resource from the pool 2、简要分析: redis.clients.util.Pool.getResource会从JedisPool实例池中返回一个可用的redis连接。分析源码可知JedisPool 继承了 r…...
【广州华锐互动】Web3D云展编辑器能为展览行业带来哪些便利?
在数字时代中,传统的展览方式正在被全新的技术和工具所颠覆。其中,最具有革新意义的就是Web3D云展编辑器。这种编辑器以其强大的功能和灵活的应用,正在为展览设计带来革命性的变化。 广州华锐互动开发的Web3D云展编辑器是一种专门用于创建、编…...
Vue项目实战之一----实现分类弹框效果
效果图 实现 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><title>Title</title><script src"js/vue.js"></script><!-- 引入样式 --><link rel"stylesheet&qu…...
Vue解析器
解析器本质上是一个状态机。但我们也曾提到,正则表达式其实也是一个状态机。因此在编写 parser 的时候,利用正则表达式能够让我们少写不少代码。本章我们将更多地利用正则表达式来实现 HTML 解析器。另外,一个完善的 HTML 解析器远比想象的要…...
Spring Cloud 版本升级遇坑记:OpenFeignClient与Gateway的恩怨情仇
Spring Cloud 版本升级遇坑记:OpenFeignClient与Gateway的恩怨情仇 近日,在对项目中的 Spring Boot、Spring Cloud 以及 Spring Cloud Alibaba 进行版本升级时,遭遇了一个令人头疼的问题:Spring Cloud Gateway 在运行时一直卡住&a…...
面试:Docker相关问题
文章目录 请解释一下什么是 Docker,以及它在云环境中的应用请简述Docker和LXC的区别什么是Docker Compose?请简述其作用和使用场景在使用Docker时,如何为容器创建一个可访问的网络当一个Docker容器运行异常时,如何通过Docker命令查…...
移动端浏览器 jquery 获取 pdf blob文件流 预览pdf
最近遇到一个需求,一个古早的移动端 juery 项目要求做一个页面,从接口获取 pdf 文件流,然后预览出来 这里使用第三方工具:pdf.js 代码如下: // 引入相关文件<script src"../js/pdf.js" type"text…...
Redis并发问题解决方案
目录 前言 1.分布式锁 1.基于单个节点 2.基于多个节点 3.watch(乐观锁) 2.原子操作 1.单命令操作 2.Lua 脚本(多命令操作) 3.事务 1.执行步骤 2.错误处理 3.崩溃处理 总结 前言 在多个客户端并发访问Redis的时候,虽然Redis是单线程执行指令ÿ…...
读取两个文件夹里不同名的文件,处理映射不对应的文件
解决方案:读取两个文件夹里不同名的文件,处理映射不对应的文件 # -*- coding: utf-8 -*- import ospath1 r/home/ubuntu/data/yoloData/images/train2017 path2 r/home/ubuntu/data/yoloData/labels/train2017def read_all_file_name():file_path ./t…...
SpringCloud原理-OpenFeign篇(四、请求原理)
文章目录 前言正文一、书接上回,从代理对象入手二、ReflectiveFeign.FeignInvocationHandler#invoke()三、SynchronousMethodHandler#invoke(...) 的实现原理3.1 invoke(...)源码3.2 executeAndDecode(...) 执行请求并解码 四、如何更换client 的实现 附录附1&#…...
什么是工业物联网(IOT)?这样的IOT平台你需要吗?——青创智通
物联网(IOT)是指在互联网上为传输和共享数据而嵌入传感器和软件的互联设备的广泛性网络。这允许将从物理对象收集的信息(数据)存储在专用服务器或云中。通过分析这些积累的信息,通过提供最优的设备控制和方法,可以实现一个更安全、更方便的社会。在智能家…...
MTK Pump Express 快速充电原理分析
1 MTK PE 1.1 原理 在讲正文之前,我们先看一个例子。 对于一块电池,我们假设它的容量是6000mAh,并且标称电压是3.7V,换算成Wh(瓦时)为单位的值是22.3Wh(6000mAh*3.7V);普通的充电器输出电压电流是5V2A(10W),…...
leetcode刷题记录——1991. 找到数组的中间位置
找到数组的中间位置 给你一个下标从 0 开始的整数数组 nums ,请你找到 最左边 的中间位置 middleIndex (也就是所有可能中间位置下标最小的一个)。 中间位置 middleIndex 是满足 nums[0] nums[1] … nums[middleIndex-1] nums[middleInd…...
跨域攻击分析和防御(上)
点击星标,即时接收最新推文 跨域攻击 在大型公司或大型跨国企业中都拥有自己的内网,跨国公司都有各个子公司一般以建立域林进行共享资源。根据不同职能区分的部门,从逻辑上以主域和子域进行划分以方便统一管理。在物理层使用防火墙将各个子公…...
GEE:梯度提升树(Gradient Boosting Tree)分类教程(样本制作、特征添加、训练、精度、参数优化、贡献度、统计面积)
作者:CSDN @ _养乐多_ 本文将介绍在Google Earth Engine (GEE)平台上进行梯度提升树(Gradient Boosting Tree)分类的方法和代码,其中包括制作样本点教程(本地、在线和本地在线混合制作样本点,合并样本点等),加入特征变量(各种指数、纹理特征、时间序列特征、物候特征…...
ubuntu22.04 arrch64版在线安装redis
脚本 apt-key adv --keyserver keyserver.ubuntu.com --recv-keys 40976EAF437D05B5 apt-key adv --keyserver keyserver.ubuntu.com --recv-keys 3B4FE6ACC0B21F32 echo "deb http://archive.ubuntu.com/ubuntu/ trusty main universe restricted multiverse" >…...
智能家居项目翻车实录:聊聊嵌入式IoT开发中那些容易踩的坑(附避坑指南)
智能家居开发实战:嵌入式IoT项目避坑指南 去年我接手了一个智能家居中控系统的开发项目,原本以为凭借多年的嵌入式开发经验能够轻松搞定,结果却遭遇了各种意想不到的问题——设备频繁离线、传感器数据延迟、OTA升级失败……这些问题不仅让项目…...
仅限省级智慧农业中心获取:Docker 27定制化RPM包(预集成Modbus TCP/DTU驱动+国密SM4加密模块),含27个预编译镜像哈希值与硬件兼容性矩阵表
第一章:Docker 27 农业物联网部署案例在山东寿光某现代化蔬菜大棚基地,运维团队基于 Docker 27(2024年1月发布的 LTS 版本)构建了轻量、可复现的农业物联网边缘计算平台。该平台整合土壤温湿度传感器、CO₂浓度探头、智能滴灌控制…...
【路由原理与路由协议-MPLS多协议标签转换】
路由原理与路由协议-MPLS多协议标签转换一、概念二、原理三、流程四、P/PE/CE路由器一、概念 1.MPLS位于OSI模型第2.5层的核心网络技术,它结合了二层(数据链路层)交换的高速性与三层(网络层)路由的灵活性,…...
RK3588音频子系统DTS配置避坑:为什么你的ES8388声卡没声音?
RK3588音频子系统DTS配置深度排查:ES8388无声问题的系统性解决方案 当你在RK3588平台上调试ES8388音频编解码器时,最令人沮丧的莫过于所有配置看起来都正确,但系统就是死活不出声。这种问题往往不是单一因素导致的,而是多个环节的…...
建议收藏|2026 版:35 岁程序员转型大模型 AI,完整路线 + 岗位拆解
当人工智能(AI)全面从技术验证走向规模化产业落地,从通用大模型的深度交互、多模态智能生成,到自动驾驶的持续迭代、工业场景的智能质检,再到医疗 AI 精准诊断、金融大模型智能风控与投研分析,这股技术浪潮…...
手把手教你用STM32CubeMX配置SPI2,5分钟搞定RC522门禁卡读写
STM32CubeMX实战:5分钟完成RC522门禁卡系统开发 在物联网和智能硬件快速发展的今天,门禁系统作为安防领域的重要组成部分,正经历着从传统向智能化的转变。而RFID技术凭借其非接触式识别的特性,成为门禁系统的核心技术之一。本文将…...
嵌入式系统模型检查与执行时间分析技术
1. 模型检查与可达性分析基础在嵌入式系统开发中,形式化验证技术正变得越来越重要。模型检查作为其中的关键技术之一,能够系统地验证系统是否满足特定的时态逻辑规范。让我们从一个实际案例开始理解这个概念。案例:汽车刹车系统验证想象一个电…...
Apache Cloudberry 2.1.0 发布:多方面改进,积极推进 PostgreSQL 内核升级
Apache Cloudberry 2.1.0 正式发布,继 2.0.0 版本后继续改进数据库内核等。本次更新在查询执行、存储等方面有多项改进,还更新了生态系统组件,且正推进 PostgreSQL 内核升级。版本更新背景Apache Cloudberry 在 2.0.0 版本发布后,…...
从‘炼丹’到‘工程’:复盘InceptionV3论文中那些被验证与‘打脸’的设计(附代码对比)
从‘炼丹’到‘工程’:InceptionV3设计思想的现代验证与技术启示 当我们在2023年回望2015年问世的InceptionV3架构,会发现它像一座横跨深度学习"炼丹时代"与"工程时代"的桥梁。这篇论文最珍贵的遗产不是某个具体模块,而是…...
Windows 11安装终极指南:如何用MediaCreationTool.bat轻松绕过硬件限制
Windows 11安装终极指南:如何用MediaCreationTool.bat轻松绕过硬件限制 【免费下载链接】MediaCreationTool.bat Universal MCT wrapper script for all Windows 10/11 versions from 1507 to 21H2! 项目地址: https://gitcode.com/gh_mirrors/me/MediaCreationTo…...
