美文网首页
【原创】二、关于HDFS、YARN及MapReduce的理解

【原创】二、关于HDFS、YARN及MapReduce的理解

作者: wind001 | 来源:发表于2017-01-25 12:19 被阅读0次

一、HDFS

HDFS是分布式文件系统,有高容错性的特点,可以部署在价格低廉的服务器上,主要包含namenode和datanode。

Namenode是hdfs中文件目录和文件分配管理者,它保存着文件名和数据块的映射管理,数据块和datanode列表的映射关系。其中文件名和数据块的关系保存在磁盘上,但是namenode上不保存数据块和datanode列表的关系,该列表是通过datanode上报建立起来的。

Namenode上的有三种交互,1、client访问namenode获取的相关datanode的信息。2、datanode心跳汇报当前block的情况。3、secondarynamenode做checkpoint交互。

DataNode它负责实际的数据存储,并将数据息定期汇报给NameNode。DataNode以固定大小的block为基本单位组织文件内容,默认情况下block大小为128MB。当用户上传一个大的文件到HDFS上时,该文件会被切分成若干个block,分别存储到不同的DataNode;同时,为了保证数据可靠,会将同一个block以流水线方式写到若干个(默认是3,该参数可配置)不同的DataNode上。这种文件切割后存储的过程是对用户透明的。

SecondaryNameNode,用来辅助namenode进行元数据的合并,并且传回到namenode。

二、YARN

YARN主要包括几种角色

ResourceManager(RM):主要接收客户端任务请求,接收和监控NodeManager(NM)的资源情况汇报,负责资源的分配与调度,启动和监控ApplicationMaster(AM),一个集群只有一个。

NodeManager:主要是节点上的资源管理,启动Container运行task计算,上报资源、container情况给RM和任务处理情况给AM,整个集群有多个。

ApplicationMaster:主要是单个Application(Job)的task管理和调度,向RM进行资源的申请,向NM发出launch Container指令,接收NM的task处理状态信息。每个应用有一个。

Container:是YARN中资源的抽象,它封装了某个节点上一定量的资源(CPU和内存两类资源)。

三、MapReduce

MapReduce是hadoop的一种离线计算框架,适合离线批处理,具有很好的容错性和扩展性,适合简单的批处理任务。缺点启动开销大,任务多使用磁盘效率比较低。

一个MapReduce作业通常会把输入的数据集切分为若干独立的数据块,由map任务(task)以完全并行的方式处理它们。框架会对map的输出先进行排序,然后把结果输入给reduce任务。通常作业的输入和输出都会被存储在文件系统中。整个框架负责任务的调度和监控,以及重新执行已经失败的任务。通常,MapReduce框架和分布式文件系统是运行在一组相同的节点上的,计算节点和存储节点通常在一起。这种配置允许框架在那些已经存好数据的节点上高效地调度任务,这可以使整个集群的网络带宽被非常高效地利用。

一个MapReduce任务包含一般会这几个部分:Map、Shuffle(Sort、Partitioner、Combiner、Merge、Sort)、Reduce。

相关文章

  • 【原创】二、关于HDFS、YARN及MapReduce的理解

    一、HDFS HDFS是分布式文件系统,有高容错性的特点,可以部署在价格低廉的服务器上,主要包含namenode和...

  • MapReduce

    HDFS与YARN的关系HDFS与YARN.png Map与Reduce MapReduce架构 shuffle ...

  • 大数据生态系统

    hadoop里面可分为HDFS和mapreduce和yarn HDFS(Hadoop Distributed Fi...

  • Hadoop

    狭义 Hadoop HDFS MapReduce Yarn 资源调度 广义 Hadoop辅助框架 flume 日志...

  • 大数据关于HDFS、YARN及MapReduce的总结

    前言: 有很多小伙伴对这几个东西的概念有些模糊,这里我做一个总结,希望大家能一篇看懂。 一、HDFS HDFS是分...

  • hadoop

    Hadoop构成 分布式存储HDFS 分布式计算MapReduce 资源调度引擎Yarn HDFS: 块级别的分布...

  • Hadoop集群的搭建

    hdfs集群:负责文件读写/namenode、datanode yarn集群:负责为mapreduce分配运算硬件...

  • 2018-05-30 开胃学习Data系列 - Hadoop(未

    Hadoop主要由HDFS + YARN + MapReduce三个核心组件组成,HDFS是一个文件系统,负责分布...

  • Hadoop 面试题

    hadoop组成? MapReduce 计算Yarn 资源调度hdfs 数据存储Common 辅助工具 如...

  • HDFS、YARN、Mapreduce概述

    当今时代,互联网世界中每天都有数以亿计的数据产出,比如某东某宝的商城订单,日志流量等数据,越来越多的小伙伴都投身大...

网友评论

      本文标题:【原创】二、关于HDFS、YARN及MapReduce的理解

      本文链接:https://www.haomeiwen.com/subject/ievtittx.html