Hadoop基础入门学习笔记(基本概念)

本文涉及的产品
日志服务 SLS,月写入数据量 50GB 1个月
简介:

一、数据块(blck)

HDFS(Hadp Distributed File System)默认的最基本的存储单位是64M的数据块。 

和普通文件系统相同的是,HDFS中的文件是被分成64M一块的数据块存储的。 

不同于普通文件系统的是,HDFS中,如果一个文件小于一个数据块的大小,并不占用整个数据块存储空间。

二、元数据节点(Namende)和数据节点(datande)

元数据节点用来管理文件系统的命名空间 

其将所有的文件和文件夹的元数据保存在一个文件系统树中。 

这些信息也会在硬盘上保存成以下文件:命名空间镜像(namespace image)及修改日志(edit lg) 

其还保存了一个文件包括哪些数据块,分布在哪些数据节点上。然而这些信息并不存储在硬盘上,而是在系统启动的时候从数据节点收集而成的。

数据节点是文件系统中真正存储数据的地方。 

客户端(client)或者元数据信息(namende)可以向数据节点请求写入或者读出数据块。 

其周期性的向元数据节点回报其存储的数据块信息。

从元数据节点(secndary namende) 

从元数据节点并不是元数据节点出现问题时候的备用节点,它和元数据节点负责不同的事情。 

其主要功能就是周期性将元数据节点的命名空间镜像文件和修改日志合并,以防日志文件过大。这点在下面会详细叙述。 

合并过后的命名空间镜像文件也在从元数据节点保存了一份,以防元数据节点失败的时候,可以恢复。


1、 元数据节点文件夹结构

wKiom1OipcySBImuAAArHDigtj0216.jpg


VERSIN文件是java prperties文件,保存了HDFS的版本号。 

layutVersin是一个负整数,保存了HDFS的持续化在硬盘上的数据结构的格式版本号。 

namespaceID是文件系统的唯一标识符,是在文件系统初次格式化时生成的。 

cTime此处为0 

strageType表示此文件夹中保存的是元数据节点的数据结构。

1
2
3
4
namespaceID=1232737062
cTime=0
strageType=NAME_NDE
layutVersin=-18


2、文件系统命名空间映像文件及修改日志

当文件系统客户端(client)进行写操作时,首先把它记录在修改日志中(edit lg) 

元数据节点在内存中保存了文件系统的元数据信息。在记录了修改日志后,元数据节点则修改内存中的数据结构。 

每次的写操作成功之前,修改日志都会同步(sync)到文件系统。 

fsimage文件,也即命名空间映像文件,是内存中的元数据在硬盘上的checkpint,它是一种序列化的格式,并不能够在硬盘上直接修改。 

同数据的机制相似,当元数据节点失败时,则最新checkpint的元数据信息从fsimage加载到内存中,然后逐一重新执行修改日志中的操作。 

从元数据节点就是用来帮助元数据节点将内存中的元数据信息checkpint到硬盘上的 

checkpint的过程如下: 

从元数据节点通知元数据节点生成新的日志文件,以后的日志都写到新的日志文件中。 

从元数据节点用http get从元数据节点获得fsimage文件及旧的日志文件。 

从元数据节点将fsimage文件加载到内存中,并执行日志文件中的操作,然后生成新的fsimage文件。 

从元数据节点将新的fsimage文件用http pst传回元数据节点 

元数据节点可以将旧的fsimage文件及旧的日志文件,换为新的fsimage文件和新的日志文件(第一步生成的),然后更新fstime文件,写入此次checkpint的时间。 

这样元数据节点中的fsimage文件保存了最新的checkpint的元数据信息,日志文件也重新开始,不会变的很大了。

wKiom1OipjnyMmywAAH51YugcCQ205.jpg

3、从元数据节点的目录结构

wKiom1OipmaySSAvAABe1SbQG88716.jpg

4、数据节点的目录结构

wKioL1OipnajA2MMAAB6lxWeDwE035.jpg


数据节点的VERSION文件格式如下:

1
2
3
4
5
namespaceID=1232737062
storageID=DS-1640411682-127.0.1.1-50010-1254997319480
cTime=0
storageType=DATA_NODE
layoutVersion=-18

blk_<id>保存的是HDFS的数据块,其中保存了具体的二进制数据。 

        blk_<id>.meta保存的是数据块的属性信息:版本信息,类型信息,和checksum 

        当一个目录中的数据块到达一定数量的时候,则创建子文件夹来保存数据块及数据块属性信息。














本文转自南非蚂蚁51CTO博客,原文链接:http://blog.51cto.com/ixdba/1428278 ,如需转载请自行联系原作者

相关实践学习
日志服务之使用Nginx模式采集日志
本文介绍如何通过日志服务控制台创建Nginx模式的Logtail配置快速采集Nginx日志并进行多维度分析。
相关文章
|
2月前
|
存储 分布式计算 Hadoop
大数据之hadoop3入门到精通(一)
大数据之hadoop3入门到精通(一)
127 1
|
3月前
|
存储 分布式计算 Hadoop
【大数据技术Hadoop+Spark】HDFS概念、架构、原理、优缺点讲解(超详细必看)
【大数据技术Hadoop+Spark】HDFS概念、架构、原理、优缺点讲解(超详细必看)
319 0
|
2月前
|
存储 分布式计算 Hadoop
Hadoop Distributed File System (HDFS): 概念、功能点及实战
【6月更文挑战第12天】Hadoop Distributed File System (HDFS) 是 Hadoop 生态系统中的核心组件之一。它设计用于在大规模集群环境中存储和管理海量数据,提供高吞吐量的数据访问和容错能力。
451 4
|
2月前
|
分布式计算 Hadoop 分布式数据库
Hadoop生态系统介绍(二)大数据技术Hadoop入门理论系列之一----hadoop生态圈介绍
Hadoop生态系统介绍(二)大数据技术Hadoop入门理论系列之一----hadoop生态圈介绍
118 2
|
2天前
|
存储 分布式计算 资源调度
Hadoop入门基础(一):深入探索Hadoop内部处理流程与核心三剑客
Hadoop入门基础(一):深入探索Hadoop内部处理流程与核心三剑客
|
3月前
|
存储 分布式计算 监控
Hadoop【基础知识 01+02】【分布式文件系统HDFS设计原理+特点+存储原理】(部分图片来源于网络)【分布式计算框架MapReduce核心概念+编程模型+combiner&partitioner+词频统计案例解析与进阶+作业的生命周期】(图片来源于网络)
【4月更文挑战第3天】【分布式文件系统HDFS设计原理+特点+存储原理】(部分图片来源于网络)【分布式计算框架MapReduce核心概念+编程模型+combiner&partitioner+词频统计案例解析与进阶+作业的生命周期】(图片来源于网络)
236 2
|
6天前
|
存储 分布式计算 Hadoop
|
2月前
|
存储 分布式计算 安全
大数据之hadoop3入门到精通(三)
大数据之hadoop3入门到精通(三)
|
2月前
|
SQL 资源调度 大数据
大数据之hadoop3入门到精通(二)
大数据之hadoop3入门到精通(二)
|
3月前
|
存储 分布式计算 Hadoop
Hadoop节点数据块概念与功能
【5月更文挑战第21天】
53 1