HDFS(Hadoop Distributed File System )Hadoop分布式文件系统。

是依据google发表的论文翻版的。论文为GFS(Google File System)Google 文件系统(中文英文)。

HDFS有非常多特点

① 保存多个副本,且提供容错机制,副本丢失或宕机自己主动恢复。默认存3份。

② 执行在便宜的机器上。

③ 适合大数据的处理。

多大?多小?HDFS默认会将文件切割成block,64M为1个block。然后将block按键值对存储在HDFS上,并将键值对的映射存到内存中。假设小文件太多,那内存的负担会非常重。

如上图所看到的。HDFS也是依照Master和Slave的结构。分NameNode、SecondaryNameNode、DataNode这几个角色。

NameNode:是Master节点,是大领导。管理数据块映射。处理client的读写请求;配置副本策略;管理HDFS的名称空间;

SecondaryNameNode:是一个小弟。分担大哥namenode的工作量;是NameNode的冷备份;合并fsimage和fsedits然后再发给namenode。

DataNode:Slave节点,奴隶,干活的。负责存储client发来的数据块block;运行数据块的读写操作。

热备份:b是a的热备份。假设a坏掉。那么b立即执行取代a的工作。

冷备份:b是a的冷备份,假设a坏掉。那么b不能立即取代a工作。可是b上存储a的一些信息,降低a坏掉之后的损失。

fsimage:元数据镜像文件(文件系统的文件夹树。)

edits:元数据的操作日志(针对文件系统做的改动操作记录)

namenode内存中存储的是=fsimage+edits。

SecondaryNameNode负责定时默认1小时,从namenode上,获取fsimage和edits来进行合并。然后再发送给namenode。

降低namenode的工作量。


工作原理

写操作:

有一个文件FileA,100M大小。Client将FileA写入到HDFS上。

HDFS按默认配置。

HDFS分布在三个机架上Rack1,Rack2,Rack3。

a. Client将FileA按64M分块。分成两块。block1和Block2;

b. Client向nameNode发送写数据请求,如图蓝色虚线①------>。

c. NameNode节点,记录block信息。并返回可用的DataNode。如粉色虚线②--------->。

Block1: host2,host1,host3

Block2: host7,host8,host4

原理:

NameNode具有RackAware机架感知功能,这个能够配置。

若client为DataNode节点,那存储block时,规则为:副本1,同client的节点上。副本2。不同机架节点上;副本3。同第二个副本机架的还有一个节点上;其它副本随机挑选。

若client不为DataNode节点。那存储block时。规则为:副本1。随机选择一个节点上;副本2,不同副本1,机架上。副本3,同副本2同样的还有一个节点上。其它副本随机挑选。

d. client向DataNode发送block1;发送过程是以流式写入。

流式写入过程。

1>将64M的block1按64k的package划分;

2>然后将第一个package发送给host2;

3>host2接收完后。将第一个package发送给host1,同一时候client想host2发送第二个package;

4>host1接收完第一个package后,发送给host3,同一时候接收host2发来的第二个package。

5>以此类推。如图红线实线所看到的,直到将block1发送完成。

6>host2,host1,host3向NameNode,host2向Client发送通知,说“消息发送完了”。

如图粉红颜色实线所看到的。

7>client收到host2发来的消息后,向namenode发送消息。说我写完了。

这样就真完毕了。如图黄色粗实线

8>发送完block1后,再向host7,host8,host4发送block2,如图蓝色实线所看到的。

9>发送完block2后。host7,host8,host4向NameNode,host7向Client发送通知,如图浅绿色实线所看到的。

10>client向NameNode发送消息,说我写完了。如图黄色粗实线。。

这样就完成了。

分析,通过写过程,我们能够了解到:

写1T文件,我们须要3T的存储,3T的网络流量贷款。

在运行读或写的过程中。NameNode和DataNode通过HeartBeat进行保存通信,确定DataNode活着。假设发现DataNode死掉了,就将死掉的DataNode上的数据,放到其它节点去。

读取时,要读其它节点去。

挂掉一个节点,没关系。还有其它节点能够备份。甚至。挂掉某一个机架,也没关系;其它机架上,也有备份。

读操作:

读操作就简单一些了,如图所看到的,client要从datanode上,读取FileA。而FileA由block1和block2组成。

那么。读操作流程为:

a. client向namenode发送读请求。

b. namenode查看Metadata信息,返回fileA的block的位置。

block1:host2,host1,host3

block2:host7,host8,host4

c. block的位置是有先后顺序的,先读block1,再读block2。

并且block1去host2上读取;然后block2。去host7上读取;

上面样例中,client位于机架外。那么假设client位于机架内某个DataNode上,比如,client是host6。那么读取的时候,遵循的规律是:

优选读取本机架上的数据

HDSF主要节点解说(二)工作原理的更多相关文章

  1. Struts2(二)工作原理

    一.概述 1.struts框架本身分为三个部分:核心控制器FilterDispatcher.业务控制器Action和用户实现的企业业务逻辑组件. 2.struts2工作的基本流程: 客户端初始化一个指 ...

  2. MongoDB复制集的工作原理介绍(二)

    复制集工作原理 1)数据复制原理 开启复制集后,主节点会在 local 库下生成一个集合叫 oplog.rs,这是一个有限集合,也就是大小是固定的.其中记录的是整个mongod实例一段时间内数据库的所 ...

  3. 分布式的几件小事(二)dubbo的工作原理

    1.dubbo的工作原理 ①整体设计 图例说明: 图中左边淡蓝背景的为服务消费方使用的接口,右边淡绿色背景的为服务提供方使用的接口,位于中轴线上的为双方都用到的接口. 图中从下至上分为十层,各层均为单 ...

  4. 代码管理工具 --- git的学习笔记二《git的工作原理》

    通过几个问题来学习代码管理工具之git 一.git是什么?为什么要用它?使用它的好处?它与svn的区别,在Mac上,比较好用的git图形界面客户端有 git 是分布式的代码管理工具,使用它是因为,它便 ...

  5. android camera(二):摄像头工作原理、s5PV310 摄像头接口(CAMIF)

    一.摄像头工作原理 上一篇我们讲了摄像头模组的组成,工作原理,做为一种了解.下面我们析摄像头从寄存器角度是怎么工作的.如何阅读摄像头规格书(针对驱动调节时用到关键参数,以GT2005为例). 规格书, ...

  6. 【转】android camera(二):摄像头工作原理、s5PV310 摄像头接口(CAMIF)

    关键词:android  camera CMM 模组 camera参数  CAMIF平台信息:内核:linux系统:android 平台:S5PV310(samsung exynos 4210) 作者 ...

  7. JVM工作原理和特点(一些二逼的逼神面试官会问的问题)

    作为一种阅读的方式了解下jvm的工作原理 ps:(一些二逼的逼神面试官会问的问题) JVM工作原理和特点主要是指操作系统装入JVM是通过jdk中Java.exe来完毕,通过以下4步来完毕JVM环境. ...

  8. 关系型数据库工作原理-事务管理(二)(翻译自Coding-Geek文章)

    本文翻译自Coding-Geek文章:< How does a relational database work>. 原文链接:http://coding-geek.com/how-dat ...

  9. JAVA之旅(二十五)——文件复制,字符流的缓冲区,BufferedWriter,BufferedReader,通过缓冲区复制文件,readLine工作原理,自定义readLine

    JAVA之旅(二十五)--文件复制,字符流的缓冲区,BufferedWriter,BufferedReader,通过缓冲区复制文件,readLine工作原理,自定义readLine 我们继续IO上个篇 ...

随机推荐

  1. EF连接MySQL数据Web.Config配置

    EF连接MySQL数据Web.Config配置 <?xml version="1.0" encoding="utf-8"?> <configu ...

  2. GitHub详解(转)

    GitHub 是一个共享虚拟主机服务,用于存放使用Git版本控制的软件代码和内容项目.它由GitHub公司(曾称Logical Awesome)的开发者Chris Wanstrath.PJ Hyett ...

  3. UVA - 12119 The Bells are Ringing (枚举)

    Perhaps you all have heard the mythical story about Tower of Hanoi (The details of this story is not ...

  4. win 8.1 安装 SQL server 遇到的各种问题

    企业版 SQL Server ed2k://|file|cn_sql_server_2012_enterprise_edition_x86_x64_dvd_813295.iso|5054384128| ...

  5. Tomcat启动会遇到的问题部分解决方案

    Tomcat的启动不一定会非常的顺利,这可以有多种原因 一.Tomcat是由Java所编写的,因此Tomcat的使用需要JDK的支持,如果没有配置环境变量,Tomcat当然无法启动,最明显的特征就是点 ...

  6. qt新进程工作目录的设置(工作目录确实是被子进程继承的,但也可以设置)

    经过试验,qt启动一个新的进程时,这个进程的工作目录是继承父进程的,无论是通过start还是startDetached来启动. 其实对于linux系统,qt底层应该也是调用fork.exec之类的函数 ...

  7. 手把手教你_android自己主动化实践方案选型

    接到一个android自己主动化的任务,看了看手中的家伙:ranorex,appium,uiautomator 当然先捡商用的试试,简单呀,能够录制回放,只是不是抱特别大的期望,这个爷比較娇气,要是a ...

  8. NET Core全新的配置管理

    NET Core全新的配置管理[共9篇] 提到“配置”二字,我想绝大部分.NET开发人员脑海中会立马浮现出两个特殊文件的身影,那就是我们再熟悉不过的app.config和web.config,多年以来 ...

  9. SilkTest Q&A 2

    Q11:SilkTest中有没有计算web页面上单词数量的函数? A11:你可以使用Clipboard函数.使用Ctrl+a和Ctrl+c,然后解析string的list. Q12:silktest的 ...

  10. Hbase集群环境搭建

    Hbase数据库依赖 Hadoop和zookeeper,所以,安装Hbase之前,需要先把zookeeper集群搭建好.(当然,Hbase有内建的zookeeper,不过不建议使用).Hbase配置上 ...