HDFS笔记(一)
1. HDFS 是什么?
Hadoop分布式文件系统(Distributed File System)-HDFS(Hadoop Distributed File System)
2. HDFS 架构

首先HDFS是一个分布式文件系统,就是说在一个集群上做了一个文件系统。一般的集群都是主从结构。namenode是主,datenode是从。
我们来看一下这几个概念
Client:就是客户端。
1、文件切分。文件上传 HDFS 的时候,Client 将文件切分成 一个一个的Block,然后进行存储。
2、与 NameNode 交互,获取文件的位置信息。
3、与 DataNode 交互,读取或者写入数据。
4、Client 提供一些命令来管理 HDFS,比如启动或者关闭HDFS。
5、Client 可以通过一些命令来访问 HDFS。
NameNode:就是 master,它是一个主管、管理者。
1.管理者文件系统命名空间
--维护着文件树及树中的所有文件和目录
2.存储元数据
--namenodde 保存元信息的种类有
文件名目录名及它们之间的层级关系
文件目录和所有者及其权限
每个文件块和名及文件有哪些块组成
注:元数据保存在内存中
namenode元信息并不包含每个块的位置信息
3.保存文件,block,datanode 之间的映射关系
4.配置副本策略
5.处理客户端读写请求
DataNode:就是Slave。NameNode 下达命令,DataNode 执行实际的操作。
1.负责存储实际的数据块,负责为系统客户端提供数据块的读写服务
2.根据NameNode 的指示进行创建、删除和复制等操作
3.心跳机制,定期报告文件块列表信息
4.datanode之间进行通信,块的副本处理
Secondary NameNode:并非 NameNode 的热备。当NameNode 挂掉的时候,它并不能马上替换 NameNode 并提供服务。
1、辅助 NameNode,分担其工作量。
2、定期合并 fsimage和fsedits,并推送给NameNode。
3、在紧急情况下,可辅助恢复 NameNode。
3. HDFS上传流程

过程解析:
这里描述的 是一个256M的文件上传过程
① 由客户端 向 NameNode节点节点 发出请求
② NameNode 向Client返回可以可以存数据的 DataNode 这里遵循 机架感应 原则
③ 客户端 首先 根据返回的信息 先将 文件分块(Hadoop2.X版本 每一个block为 128M 而之前的版本为 64M)
④ 然后通过那么Node返回的DataNode信息 直接发送给DataNode 并且是 流式写入 同时 会复制到其他两台机器
⑤ dataNode 向 Client通信 表示已经传完 数据块 同时向NameNode报告
⑥ 依照上面(④ 到 ⑤)的原理将 所有的数据块都上传结束 向 NameNode 报告 表明 已经传完所有的数据块
这样 整个HDFS上传流程就 走完了
HDFS笔记(一)的更多相关文章
- HDFS笔记——技术点汇总
		
目录 · 概况 · 原理 · HDFS 架构 · 块 · NameNode · SecondaryNameNode · fsimage与edits合并 · DataNode · 数据读写 · 容错机制 ...
 - hdfs笔记
		
Distributed File System 数据量越来越多,在一个操作系统管辖的范围存不下了,那么就分配到更多的操作系统管理的磁盘中,但是不方便管理和维护,因此迫切需要一种系统来管理多台机器上的文 ...
 - 【Hadoop】HDFS笔记(三):HDFS的Shell操作
		
HDFS处理文件的命令和Linux命令差不多,但注意区分大小写. (Linux区分大小写,Windows不区分大小写) 一.fs命令 键入命令"./bin/hadoop fs"将输 ...
 - 【Hadoop】HDFS笔记(二):HDFS的HA机制和Federation机制
		
HA解决了HDFS的NameNode的单点问题: Federation解决了整个HDFS集群中只有一个名字空间,并且只有单独的一个NameNode管理所有DataNode的问题. 一.HA机制(Hig ...
 - 【Hadoop】HDFS笔记(一):Hadoop的RPC机制
		
RPC(Remote Procedure Call, 远程过程调用)主要面对两个问题: 1.对象调用方式: 2.序列/反序列化机制. Hadoop实现的RPC组件依赖于Hadoop Writable类 ...
 - HDFS笔记(二)
		
fsimage : NameNode启动时,对文件系统的快照 eidt logs : NameNode启动后,对文件系统的改动序列 namenode在全局里就一个进程,所以存在单点问题 DataNod ...
 - 学习笔记—MapReduce
		
MapReduce是什么 MapReduce是一种分布式计算编程框架,是Hadoop主要组成部分之一,可以让用户专注于编写核心逻辑代码,最后以高可靠.高容错的方式在大型集群上并行处理大量数据. Map ...
 - Hadoop1.x HDFS系统架构
		
1. HDFS中的一些概念1.1 数据块1.2 NameNode和DataNode1.2.1 管理者:Namenode1.2.1 工作者:Datanode1.3 Secondary Namenode1 ...
 - HDFS Federation (读书笔记)
		
HDFS Federation (读书笔记) HDFS的架构 HDFS包含两个层次:命名空间管理(Namespace) 和 块/存储管理(Block Storage). 命名空间管理(Namespac ...
 
随机推荐
- 计算机基础:计算机网络-chapter6应用层
			
应用层为协议最顶部,为用户服务. 常见的服务:邮件,万维网,DNS等 DNS:使用UDP承载,部分使用TCP协议 作用 将域名映射为IP 域名格式:自己到上级域名的访问 DNS服务器提供域名的资源记录 ...
 - Android Studio 每次运行都会再下载一遍,修改
			
Android Studio 每次运行都会再下载一遍 把 gradle 设置 use local gradle distribution
 - 为什么fork()2次会避免产生僵尸进程
			
什么是僵尸进程:用fork()创建子进程后,子进程已终止但父进程没有对它进行善后处理,那么子进程的进程描述符就一直保存在内存中,子进程就是僵尸进程. 怎么产生僵尸进程: 1.父进程没有SIGCHLD信 ...
 - cookie猜数字游戏(下)------------以及cookie使用的不安全之处
			
1.通过cookie可以解决上篇中多个用户对数据的修改,每个COOKIE保存不同用户的数据 <?php if(empty($_COOKIE['num'])||empty($_GET['num'] ...
 - 微信小程序:图片预览
			
wxml页面: <image src='{{UPLOAD_IMAGES_URL}}{{vv.img_s}}' data-src="{{vv.img}}" bindtap=&q ...
 - maven编译或者打包web项目显示“软件包 javax.servlet.http 不存在"
			
2.解决办法: 这是由于缺少servlet-api.jar包,其实tomcat下有,但是在java build path把他加载过来,还是报这个错误,所以我们直接在pom.xml里面加入这个jar包即 ...
 - CodeChef - BLACKCOM  可行性dp转最优化树dp
			
https://www.codechef.com/problems/BLACKCOM 题意:一颗5000个黑白结点的树,10W个查询寻找是否存在大小s并且有t和黑节点的子图 一开始就觉得应当是一个树d ...
 - django中文学习资料
			
Django 2.0 中文官方文档地址: https://docs.djangoproject.com/zh-hans/2.0/ <Django Girls>中文版地址: https:// ...
 - OS + linux proxy
			
s Linux主机通过代理服务器进行网络连接 http://www.linuxidc.com/Linux/2015-01/111703.htm 新手用Linux做代理服务器 三招搞定 http://b ...
 - 10、 在QQ音乐中爬取某首歌曲的歌词
			
需求就是把关卡内的代码稍作修改,将周杰伦前五页歌曲的歌词都爬取下来,结果就是全部展示打印出来. URL https://y.qq.com/portal/search.html#p ...