2024年5月29日发(作者:)

谷歌三大核心技术(一)Google File System中文版

您的评价:

收藏该经验

不错

The Google File System中文版

译者:alex

摘要

我们设计并实现了Google GFS文件系统,一个面向大规模数据密集型应用的、可伸缩的

分布式文件系统。GFS虽然运行在廉价的普遍硬件设备上,但是它依然了提供灾难冗余的

能力,为大量客户机提供了高性能的服务。

虽然GFS的设计目标与许多传统的分布式文件系统有很多相同之处,但是,我们的设计还

是以我们对自己的应用的负载情况和技术环境的分析为基础 的,不管现在还是将来,GFS

和早期的分布式文件系统的设想都有明显的不同。所以我们重新审视了传统文件系统在设

计上的折衷选择,衍生出了完全不同的设计 思路。

GFS完全满足了我们对存储的需求。GFS作为存储平台已经被广泛的部署在Google内

部,存储我们的服务产生和处理的数据,同时还用于那些 需要大规模数据集的研究和开发

工作。目前为止,最大的一个集群利用数千台机器的数千个硬盘,提供了数百TB的存储

空间,同时为数百个客户机服务。

在本论文中,我们展示了能够支持分布式应用的文件系统接口的扩展,讨论我们设计的许

多方面,最后列出了小规模性能测试以及真实生产系统中性能相关数据。

分类和主题描述

D [4]: 3—D分布文件系统

常用术语

设计,可靠性,性能,测量

关键词

容错,可伸缩性,数据存储,集群存储

1. 简介

为了满足Google迅速增长的数据处理需求,我们设计并实现了Google文件系统(Google

File System – GFS)。GFS与传统的分布式文件系统有着很多相同的设计目标,比如,性

能、可伸缩性、可靠性以及可用性。但是,我们的设计还基于我们对我们自己的应用 的负

载情况和技术环境的观察的影响,不管现在还是将来,GFS和早期文件系统的假设都有明

显的不同。所以我们重新审视了传统文件系统在设计上的折衷选择, 衍生出了完全不同的

设计思路。

首先,组件失效被认为是常态事件,而不是意外事件。GFS包括几百甚至几千台普通的廉

价设备组装的存储机器,同时被相当数量的客户机访问。 GFS组件的数量和质量导致在

事实上,任何给定时间内都有可能发生某些组件无法工作,某些组件无法从它们目前的失

效状态中恢复。我们遇到过各种各样的问 题,比如应用程序bug、操作系统的bug、人为

失误,甚至还有硬盘、内存、连接器、网络以及电源失效等造成的问题。所以,持续的监

控、错误侦测、灾难冗 余以及自动恢复的机制必须集成在GFS中。

其次,以通常的标准衡量,我们的文件非常巨大。数GB的文件非常普遍。每个文件通常

都包含许多应用程序对象,比如web文档。当我们经常需要处 理快速增长的、并且由数

亿个对象构成的、数以TB的数据集时,采用管理数亿个KB大小的小文件的方式是非常

不明智的,尽管有些文件系统支持这样的管理方 式。因此,设计的假设条件和参数,比如

I/O操作和Block的尺寸都需要重新考虑。

第三,绝大部分文件的修改是采用在文件尾部追加数据,而不是覆盖原有数据的方式。对

文件的随机写入操作在实际中几乎不存在。一旦写完之后,对文 件的操作就只有读,而且

通常是按顺序读。大量的数据符合这些特性,比如:数据分析程序扫描的超大的数据集;

正在运行的应用程序生成的连续的数据流;存档的 数据;由一台机器生成、另外一台机器

处理的中间数据,这些中间数据的处理可能是同时进行的、也可能是后续才处理的。对于

这种针对海量文件的访问模式,客户 端对数据块缓存是没有意义的,数据的追加操作是性

能优化和原子性保证的主要考量因素。

第四,应用程序和文件系统API的协同设计提高了整个系统的灵活性。比如,我们放松了

对GFS一致性模型的要求,这样就减轻了文件系统对应用程 序的苛刻要求,大大简化了

GFS的设计。我们引入了原子性的记录追加操作,从而保证多个客户端能够同时进行追加