基于Hadoop的大规模数据处理.docx

上传人:marr****208 文档编号:155806498 上传时间:2020-12-13 格式:DOCX 页数:6 大小:330.59KB
返回 下载 相关 举报
基于Hadoop的大规模数据处理.docx_第1页
第1页 / 共6页
基于Hadoop的大规模数据处理.docx_第2页
第2页 / 共6页
基于Hadoop的大规模数据处理.docx_第3页
第3页 / 共6页
基于Hadoop的大规模数据处理.docx_第4页
第4页 / 共6页
基于Hadoop的大规模数据处理.docx_第5页
第5页 / 共6页
点击查看更多>>
资源描述

《基于Hadoop的大规模数据处理.docx》由会员分享,可在线阅读,更多相关《基于Hadoop的大规模数据处理.docx(6页珍藏版)》请在金锄头文库上搜索。

1、解读:基于Hadoop的大规模数据处理系统2010-09-02 10:06 | 1775次阅读 | 【已有0条评论】发表评论 来源:csdn | 作者:王丽兵 | 收藏到我的网摘 2010年8月27日下午,由中国电子学会云计算专家委员会主办、CSDN承办的“高端云计算课程”在中关村软件园进行了免费的公开课程,公开课上座无虚席,原定几十人的教室,最终挤满了上百人。本次高端课程以“普及云计算,利用云计算,发展云计算”为基本原则,旨在为云计算领域培养和选拔更多更优秀的技术和管理人才奠定坚实的基础。在本次公开课上,中科院计算所副研究员查礼博士做了主题演讲,解密了基于Hadoop的大规模数据处理系统的组

2、成及原理。Hadoop的组成部分Hadoop是Google的MapReduce一个Java实现。MapReduce是一种简化的分布式编程模式,让程序自动分布到一个由普通机器组成的超大集群上并发执行。Hadoop主要由HDFS、MapReduce和HBase等组成。具体的组成如下图:Hadoop的组成图1. Hadoop HDFS是Google GFS存储系统的开源实现,主要应用场景是作为并行计算环境(MapReduce)的基础组件,同时也是BigTable(如HBase、HyperTable)的底层分布式文件系统。HDFS采用master/slave架构。一个HDFS集群是有由一个Nameno

3、de和一定数目的Datanode组成。Namenode是一个中心服务器,负责管理文件系统的namespace和客户端对文件的访问。Datanode在集群中一般是一个节点一个,负责管理节点上它们附带的存储。在内部,一个文件其实分成一个或多个block,这些block存储在Datanode集合里。Namenode执行文件系统的namespace操作,例如打开、关闭、重命名文件和目录,同时决定block到具体Datanode节点的映射。Datanode在Namenode的指挥下进行block的创建、删除和复制。Namenode和Datanode都是设计成可以跑在普通的廉价的运行Linux的机器上。H

4、DFS采用Java语言开发,因此可以部署在很大范围的机器上。一个典型的部署场景是一台机器跑一个单独的Namenode节点,集群中的其他机器各跑一个Datanode实例。这个架构并不排除一台机器上跑多个Datanode,不过这比较少见。HDFS体系结构图2. Hadoop MapReduce是一个使用简易的软件框架,基于它写出来的应用程序能够运行在由上千个商用机器组成的大型集群上,并以一种可靠容错的方式并行处理上TB级别的数据集。一个MapReduce作业(job)通常会把输入的数据集切分为若干独立的数据块,由 Map任务(task)以完全并行的方式处理它们。框架会对Map的输出先进行排序,然后

5、把结果输入给Reduce任务。通常作业的输入和输出都会被存储在文件系统中。整个框架负责任务的调度和监控,以及重新执行已经失败的任务。Hadoop MapReduce处理流程图3. Hive是基于Hadoop的一个数据仓库工具,处理能力强而且成本低廉。主要特点:存储方式是将结构化的数据文件映射为一张数据库表。提供类SQL语言,实现完整的SQL查询功能。1.可以将SQL语句转换为MapReduce任务运行,十分适合数据仓库的统计分析。不足之处:1.采用行存储的方式(SequenceFile)来存储和读取数据。2.效率低:当要读取数据表某一列数据时需要先取出所有数据然后再提取出某一列的数据,效率很低

6、。3.占用较多的磁盘空间。由于以上的不足,查礼博士介绍了一种将分布式数据处理系统中以记录为单位的存储结构变为以列为单位的存储结构,进而减少磁盘访问数量,提高查询处理性能。这样,由于相同属性值具有相同数据类型和相近的数据特性,以属性值为单位进行压缩存储的压缩比更高,能节省更多的存储空间。行列存储的比较图HBase是一个分布式的、面向列的开源数据库,它不同于一般的关系数据库,是一个适合于非结构化数据存储的数据库。另一个不同的是HBase基于列的而不是基于行的模式。HBase使用和 BigTable非常相同的数据模型。用户存储数据行在一个表里。一个数据行拥有一个可选择的键和任意数量的列,一个或多个列组成一个ColumnFamily,一个Fmaily下的列位于一个HFile中,易于缓存数据。表是疏松的存储的,因此用户可以给行定义各种不同的列。在HBase中数据按主键排序,同时表按主键划分为多个HRegion。HBase数据表结构图“高端云计算课程”培训将于2010年9月10日正式开始,将会介绍典型云计算平台核心算法,并透过案例讲解企业云计算发展与建设规划。欲知详情,请登录“高端云计算课程”主页。

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 高等教育 > 其它相关文档

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号