HDFS 基本原理和读写流程

本文深入探讨了HDFS的基本原理,包括其主从架构、NameNode的内存存储与持久化策略,以及DataNode的角色。详细阐述了文件的写入流程,如Block的副本放置策略,确保数据的高可用性。同时,介绍了读取流程,强调了就近读取以优化性能。此外,还提到了SecondaryNameNode的作用,即定期合并FsImage和EditLog,减少NameNode启动时间。
部署运行你感兴趣的模型镜像

HDFS 基本原理和读写流程

基本架构

HDFS是一个 主从(Master/Slaves)架构 , 由一个NameNode和一些DataNode组成,NameNode为主;
面向文件包含:文件数据(data)和文件元数据(metadata);
NameNode负责存储和管理文件元数据(在内存),并维护了一个层次型的文件目录树;
DataNode负责存储文件数据(block块),并提供block的读写;
DataNode与NameNode维持心跳,并汇报自己持有的block信息;
Client和NameNode交互文件元数据和DataNode交互文件block数据;

NameNode

  • 完全基于内存存储文件元数据、目录结构、文件block的映射
  • 需要***持久化***方案保证数据可靠性
  • 提供副本放置策略

DataNode

  • 基于本地磁盘存储block(文件的形式)
  • 并保存block的校验和数据保证block的可靠性
  • 与NameNode保持心跳,汇报block列表状态
NameNode 持久化

NameNode 使用内存来达到快速反应文件元数据的信息,但是内存的数据存在丢失的风险,所以就需要对元数据进行持久化操作;

持久化的两种方式:

  1. 当前时刻的快照:

    • 特点:使用快照进行数据恢复速度快,但是快照是间隔的,容易丢失一部分数据;
  2. 每操作记录的日志

    • 特点:完整性较好,但是恢复数据的速度慢;

NameNode 采用结合两者的方式:最近时点的 FsImage + 增量的 EditsLog(SNN 去完成)

如下:

现在10点
	FI:9点+ 9点到10点的增量的EL
	1,加载FI
	2, 加载EL
	3,内存就得到了关机前的全量数据!!!!
Hdfs 中的 (Secondary NameNode)SNN

非 HA 模式下,,SNN一般是一个独立的节点,周期完成对 NameNode 的 EditLog 向 FsImage 合并,减少 EditLog 大小,减少NameNode启动时间
根据配置文件设置的时间间隔:checkpoint.period 默认为 3600秒 或者根据配置的 editsLog 大小 fs.checkpoint.size edis 文件的最大值 默认是 64 MB

实现原理:

NameNode 安全模式

保证数据副本数,否则不对外提供服务

Namenode启动后会进入一个称为安全模式的特殊状态。
处于安全模式的Namenode是不会进行数据块的复制的。
Namenode从所有的 Datanode接收心跳信号和块状态报告。
每当Namenode检测确认某个数据块的副本数目达到这个最小值,那么该数据块就会被认为是副本安全(safely replicated)的。
在一定百分比(这个参数可配置)的数据块被Namenode检测确认是安全之后(加上一个额外的30秒等待时间),Namenode将退出安全模式状态。
接下来它会确定还有哪些数据块的副本没有达到指定数目,并将这些数据块复制到其他Datanode上。

存储模型

HDFS 写流程

  1. Client 和 NameNode 建立连接,创建文件元数据
  2. NameNode 判断元数据信息是否有效
  3. NameNode 触发副本放置策略,返回一个有序列表
  4. Client 根据返回的 DataNode 列表,建立 PipeLine 连接
  5. Client 将数据切分为 packet 发送给第一个 DataNode
  6. 第一个DataNode 接受后,会向第二个发送,第二个也是如此
Block的副本放置策略
第一个副本:放置在上传文件的DN;如果是集群外提交,则随机挑选一台磁盘不太满,CPU不太忙的节点。
第二个副本:放置在于第一个副本不同的机架上的节点。
第三个副本:与第二个副本相同机架的不同节点。
更多副本:随机节点

HDFS 读流程

为了降低整体的带宽消耗和读取延时,HDFS会尽量让读取程序读取离它最近的副本

  1. Client 向 NameNode 请求下载对应的文件
  2. NameNode 根据距离策略排序返回 BlockLocation (就近读取)
  3. Client 向指定的 DataNode 下载数据,并校验数据完整性

Client 在读取数据,获得了 Block 的元数据信息(位置和偏移量),这时HDFS 支持 Client 给出文件的 offset 自定义连接到哪些 block 的 DataNode 上,自定义获取数据; 这个是支持计算层的分治、并行计算的核心

您可能感兴趣的与本文相关的镜像

Python3.8

Python3.8

Conda
Python

Python 是一种高级、解释型、通用的编程语言,以其简洁易读的语法而闻名,适用于广泛的应用,包括Web开发、数据分析、人工智能和自动化脚本

### HDFS读写流程 #### HDFS流程HDFS 中,客户端发起文件写入请求时会经历一系列复杂的交互过程。以下是详细的写流程描述: 1. 客户端通过 `DistributedFileSystem` 创建一个文件,并向 NameNode 请求上传该文件的位置信息[^2]。 2. NameNode 接收到来自客户端的请求后,返回确认消息允许上传文件。 3. 当客户端准备上传第一个 Block 数据时,它再次向 NameNode 发起请求,询问应该将此 Block 存储在哪几个 DataNode 上。 4. NameNode 根据集群状态以及复制策略(通常为三副本),返回一组适合存储当前 Block 的 DataNode 列表(如 DN1, DN2 DN3)。 5. 客户端基于这些信息构建了一个管道用于传输数据至各个 DataNode 节点之间形成链路结构。 6. 随着数据被分割成固定大小的小块(默认情况下每个 block 大小为 128MB 或者更大一些比如 256 MB 取决于配置参数设定情况下的实际需求),它们沿着这个预先定义好的路径顺序传递给每一个参与其中负责保存相应部分副本内容的目标机器上直至全部完成整个写入动作结束为止^。 7. 如果某个阶段出现问题,则重新尝试分配新的可用资源继续执行未竟的任务直到最终成功提交所有分片后的结果集回到最初起点处等待进一步指示如何处理后续事项即可[^3]. #### HDFS流程 对于 HDFS 文件系统的读取操作而言,其基本原理如下所示: 1. 用户程序发出对某特定偏移量位置上的字节序列访问指令之后即刻触发内部机制启动检索工作链条开始运作起来寻找匹配项所在的确切物理地址以便能够迅速定位目标实体并加载相关内容呈现出来供使用者查阅学习之用[^4]. 2. Client 向 Namenode 提交查询申请获取关于所要查找记录的具体分布状况说明文档包括但不限于可能存在的多个镜像拷贝版本之间的优先级排序规则等等细节方面的考量因素都会影响到最后决策制定环节中的具体实施方案选择方向等问题都需要综合权衡利弊得失后再做定夺才行啊亲们记住啦不然的话很容易踩坑哦!!! 3. Namenode 返回最接近 client 的 datanode 地址列表作为首选方案之一提供参考依据辅助判断哪一个选项更加合适一点呢?当然咯~前提是必须满足一定的条件限制比如说网络延迟时间长短之类的硬性指标要求嘛~毕竟效率才是王道不是吗😊所以大家一定要牢记这一点哈~ 4. Client 连接到指定 datanode 并从中提取所需片段;如果遇到错误或者丢失的情况则自动切换到下一个备选站点重复上述步骤直至完全取得整份资料为止才算真正意义上的圆满达成既定目标任务哟😄 ```python # Python 示例代码展示简单的 HDFS API 使用方法来实现文件的读写功能演示效果更直观易懂些吧? from hdfs import InsecureClient client = InsecureClient('http://localhost:9870', user='root') with open('/path/to/local/file.txt', 'rb') as f: client.write('/path/in/hdfs/file.txt', f) data = client.read('/path/in/hdfs/file.txt') print(data.decode()) ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值