首页 > 其他 > 详细

hadoop学习日志

时间:2015-12-12 12:33:36      阅读:308      评论:0      收藏:0      [点我收藏+]

Hadoop思想之源:Google

  面对的数据和计算难题

    ——大量的网页怎么存储

    ——搜索算法

  带给我们的关键技术和思想

    ——GFS

    ——Map-Reduce

    ——Bigtable

  

Hadoop创始人介绍:

  Hadoop作者Doug cutting,就职Yahoo期间开发了Hadoop项目,目前在CLoudera公司从事架构工作。他不但是Hadoop项目的发起人,还是Lucene、Nutch项目的发起人。

          技术分享

 

Hadoop简介:

  ——名字来源于Hadoop之父Doug Cutting儿子的玩具大象。

  2003-2004年,Google公开了部分GFS和Mapreduce思想的细节,以此为基础Doug Cutting等人用了2年业余时间实现了DFS和Mapreduce机制,一个微缩版:Nutch。

  Hadoop于2005年秋天作为Lucene的子项目Nutch的一部分正式引入Apache基金会。2006年3月份,Map-Reduce和Nutch Distributed File System(NDFS)分别被纳入成为Hadoop的项目中。

 

  ——分布式存储系统HDFS(Hadoop Distributed File System)

    • 分布式存储系统;
    • 提供了:高可靠性、高扩展性和高吞吐率的数据存储服务;

  ——分布式计算框架Map-Reduce

    • 分布式计算框架
    • 具有易于编程、高容错性和高扩展性等优点。

 

HDFS优点:

  - 高容错性:

    • 数据自动保存多个副本
    • 副本丢失后,自动恢复(最少保留三份)

  - 高可靠性

    • Hadoop按位存储和处理数据的能力值得人们信赖

  - 高扩展性

    • Hadoop是在可用的计算机集簇间分配数据并完成计算任务,这些集簇可以方便地扩展到数以千计的节点中

  - 高效性:

    • Hadoop能够在节点之间动态地移动数据,并保证各个节点的动态平衡,因此处理速度非常快

  - 适合批处理:

    • 移动计算而非数据移动
    • 数据位置暴露给计算框架

  - 适合大数据处理:

    • GB、TB、甚至PB级数据
    • 百万规模以上的文件数量
    • 10K+节点

  - 可构建在廉价机器上:

    • 通过多副本提高可靠性
    • 提供了容错和回复机制

HDFS缺点:

  - 不适合低延迟数据访问:

    • 比如毫秒级
    • 低延迟于高吞吐率

  - 不适合小文件存取:

    • 占用NameNode大量内存
    • 寻道时间超过读取时间

  - 不支持并发写入、文件随机修改:

    • 一个文件只能有一个写者,不支持多用户写入及任意修改文件
    • 仅支持append(数据追加)

技术分享

 

HDFS数据存储元(block)

  - 文件被切分成固定大小的数据块

    • 默认数据块大小为64MB,可以配置
    • 若文件大小不到64MB,则单独存成一个bloce

  - 一个文件存储方式

    • 按大小被切分成若干个block,存储到不同节点上
    • 默认情况下每个block都有三个副本

  - Block大小和副本数通过Clien端上传文件时设置,文件上传成功后副本数可以变更,Block Size不可变更

 

HDFS设计思想:

技术分享

 

NameNode(NN):
  - NameNode主要功能:接受客户端的读写服务

  - NameNode保存metadata信息,包括:

    • 文件owership(所有者)和permissions(权限)
    • 文件包含哪些block
    • 文件包含的Block保存在哪个DataNode(由DataNode启动时上报)

  - NameNode的metadata信息在启动后会加载到内存:

    • metadata存储到磁盘文件名为“fsimage”
    • Block的位置信息不会保存到“fsimage”
    • edits记录对metadata的操作日志

    

SecondaryNameNode(SNN):

  - 它不是NameNode的备份(但可以做备份),它的主要工作是帮助NameNode合并edits log,减少NameNode启动时间

  - SecondaryNameNode执行合并时机:

    • 根据配置文件设置的时间间隔fs.checkpoint.period默认3600秒
    • 根据配置文件设置edits log大小fs.checkpoint.size规定edits文件的最大值,默认是64MB

    

DataNode(DN):

  - 存储数据(block)

  - 启动DataNode线程的时候会向NameNode汇报block信息(block位置信息),保存到NameNode的metadata(fsimage文件)中

  - 通过向NameNode发送心跳保持与其联系(3秒一次),如果NameNode10分钟没有收到DataNode的心跳,则认为其已经lost,并copy其上的block到其他DataNode,以保证每个文件的每个Block至少保存有3个副本

hadoop学习日志

原文:http://www.cnblogs.com/zhoujingyu/p/5040957.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!