Google 三大论文分别为:《Google File System》、《Google Bigtable》和《Google MapReduce》。这三大论文为大数据时代的发展奠定了理论基础,下面是我对此的一些理解。

一、GFS

Google File System 是Google公司为了存储海量搜集数据而设计的专用文件系统。是一个面向大规模数据密集型应用的、可伸缩的分布式文件系统。与普通文件系统相比,GFS 虽然仍运行在廉价的普遍硬件设备上,但是它依然了提供灾难冗余的能力,为大客户机提供了高性能的服务。

二、设计思路

GFS与以往文件系统的不同观点如下:

  • 系统由许多廉价的普通组件组成,组件失效是一种常态。

  • 系统包含一定数量的大文件。预期上数量会有几百万,文件的大小通常是GB级。

  • 系统支持两种读操作:大规模的流式读取和小规模的随机读取。在前一种读操作中,可能要读几百KB,通常达 1MB 或更多。来自同一个客户的连续操作通常会读文件的一个连续的区域。随机的读操作通常在一个随机的偏移处读几个KB。

  • 工作量还包含许多对大量数据进行的、连续的、向文件添加数据的写操作。所写的数据的规模和读相似。一旦写完,文件很少改动。在随机位置对少量数据的写操作也支持,但不必非常高效。

  • 系统必须高效地实现定义完好的大量客户同时向同一个文件的添加操作的语义。

  • 高可持续带宽比低延迟更重要

三、体系结构

1、GFS架构

  • 一个GFS集群由一个master和大量的chunkserver构成,并被许多客户端访问。

  • 每一个节点都是一个普通的Linux计算机,运行的是一个用户级别的服务器进程

  • 在GFS下,每一个文件都拆成固定大小的chunk(块)。每一个块都由master根据块创建的时间产生一个全局唯一的以后不会改变的64位的chunk -handle标志。

  • ChunkServer 将块当作Linux文件存储在本地磁盘,并可以读和写由chunk-handle和位区间指定的数据。

  • 出于可靠性的考虑,每个块都会 在不同的chunkserver上保存备份。缺省情况下,保存3个备份。

2、单master

只有一个master也极大的简化了设计并使得master可以根据全局情况作出精密的块放置和复制决定。但是我们必须要将master对读和写的参与减至最少,这样它才不会成为系统的瓶颈。

3、块规模

块规模是设计中的一个关键参数。我们选择的是64MB,这比一般的文件系统的块规模要大的多。每个块的副本作为一个普通的Linux文件存储,在需要的时候可以扩展。

块规模较大的好处有:

  • 减少client和master之间的交互。因为读写同一个块只是要在开始时向master请求块位置信息。对于读写大型文件这种减少尤为重要。即使对于访问少量数据的随机读操作也可以很方便的为一个规模达几个TB的工作集缓缓存块位置信息。
  • Client在一个给定的块上很可能执行多个操作,和一个chunkserver保持较长时间的TCP连接可以减少网络负载。
  • 这减少了master上保存的元数据(metadata)的规模,从而使得可以将metadata放在内存中。这又会带来一些别的好处。

4、快照

GFS 使用 copy-on-write 技术来实现快照。当 master 受到一个快照请求时,它首先将要快照的文件上块上的 lease 收回。这使得任何一个向这些块写数据的操作都必须和 master 交互以找到拥有 lease 的副本。

副本被撤销或终止后,master 在磁盘上登记执行的操作,然后复制源文件或目录树的 metadata 以对它的内存状态实施登记的操作。这个新创建的快照文件和源文件(其metadata)指向相同的块(chunk)。
它的内存状态实施登记的操作。这个新创建的快照文件和源文件(其metadata)指向相同的块(chunk)。

四、最后

GFS 作为 Google 公司为了存储搜集数据而设计的文件系统,虽然其源码未被公布,其理论为大数据时代的发展奠定了基础。现在知名的 hadoop 开源组件就是以Google三论文为理论设计的,HDFS 是 GFS论文的实现,只不过 HDFS 更通用而且开源。

Google三大论文之GFS相关推荐

  1. Google三大论文之 - GFS

    摘要 我们设计并实现了 Google GFS 文件系统,一个面向大规模数据密集型应用的.可伸缩的分布式文件系统. GFS 虽然运行在廉价的普遍硬件设备上,但是它依然了提供灾难冗余的能力,为大量客户机提 ...

  2. google三大论文

    Google三大论文之一:BigTable Bigtable是一个分布式的结构化数据存储系统,它被设计用来处理海量数据:通常是分布在数千台普通服务器上的PB级的数据.Google的很多项目使用Bigt ...

  3. Google三大论文读后感

    Google三大论文读后感 大数据这个词,很难对此进行明确的定义.通俗的来说,他就是我们身边的一切,眼睛所看到的,耳朵所听到的,鼻子闻到的,感觉器官所感觉到的以及一切能够描述出的信息.具体一点,我们在 ...

  4. 浅读Google三大论文

    简介 谷歌在2003到2006年间发表了三篇论文,<MapReduce: Simplified Data Processing on Large Clusters>,<Bigtabl ...

  5. Google 三大论文之——MapReduce

    MapReduce:超大机群上的简单数据处理 摘要 MapReduce是一个编程模型,和处理,产生大数据集的相关实现.用户指定一个map函数处理一个key/value对,从而产生中间的key/valu ...

  6. google三大论文之--MapReduce:超大机群上的简单数据处理

    MapReduce:超大机群上的简单数据处理                                              摘要 MapReduce是一个编程模型,和处理,产生大数据集的相 ...

  7. Google三大论文之 - BigTable

    1 摘要 Bigtable 是一个分布式的结构化数据存储系统,它被设计用来处理海量数据:通常是分布在数千台普通服务器上的 PB 级的数据. Google 的很多项目使用 Bigtable 存储数据,包 ...

  8. 现行大数据框架技术思想鼻祖--不得不看的Google三大论文(英文原文)

    GFS:http://download.csdn.net/detail/myaoyou/9688736 MapReduce:http://download.csdn.net/detail/myaoyo ...

  9. google三篇论文之GFS

    Google在03至06年发表了著名的三大论文--GFS.BigTable.MapReduce,用来实现一个大规模的管理计算系统. 今天先来谈谈GFS.因为论文里大段大段的文字加上专业术语读起来对我来 ...

最新文章

  1. MemberShip驗證
  2. 云数据管理公“云信达”获东方富海数千万A轮投资
  3. hopper_如何利用卫星收集的遥感数据轻松对蚱hopper中的站点进行建模
  4. 【原】AMR音频解码插件开发总结
  5. ps4看b站 f怎么调html5,b站html5,b站怎么切换到HTML5版播放器?
  6. java正则表达式面试_【Java面试宝典】正则表达式
  7. Oracle远程连接
  8. MySql 应用语句
  9. keras sklearn下两分类/多分类的技术杂谈(交叉验证和评价指标)
  10. 20.Azure备份Azure上的虚拟机(中)
  11. Linux 线程调度与优先级
  12. linux rzsz 安装包,安装rzsz软件包全攻略
  13. 【数学建模常用模型】分类专题
  14. 新商机:“百亿帝国”全健、华林彻底倒下,保健行业遭重创,直销业被重新定义
  15. 最佳的远程桌面连接工具
  16. JavaWeb前端: JavaScript 简介
  17. IPv6篇之即插即用
  18. 叮咚~您有一份个税申报,请查收!
  19. 认真CS☀️Unity中Newtonsoft.Json的使用
  20. UCML应用框架平台的特点

热门文章

  1. 苹果电脑删除下载的更新文件_如何为macOS启动软件自动更新
  2. jstl标签库常见用法
  3. 网上抽奖幸运数概率源码【走进JAVA-2.0】
  4. 第一节计算机课开场白,电脑课上老师的开场白
  5. 3D激光扫描三维重建——5.(matlab)系统框架
  6. Random类模拟微信发红包
  7. [转载]很有参考意义的显卡性能排行榜
  8. 如何能够使苹果手机通过插件修改信息骗过苹果服务器,使另一台手机克隆成原手机的信息呢?
  9. 广州人工智能与数字经济试验区取得初步成效
  10. waterfox同步书签