NFS文件系统源代码剖析.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
NFS文件系统源代码剖析.doc

NFS文件系统源代码剖析 2011-03-28 15:52:47 标签:NFS 文件系统 源代码 NFS文件系统是目前最为成功的网络文件系统,在文件共享领域有着出色的表现,特别是pNFS的出现,使得NFS文件系统在性能和规模上有了大幅提升,为其带了更为广阔的应用空间。同时,NFS之所以备受关注,还在于它在NAS存储领域的关键作用。本文剖析了NFSv3文件系统源代码,使开发工程师,技术支持人员,特别是存储领域从业人员对NFS有更为深刻的认识。 NFS文件系统概述 NFS(Network File System,网络文件系统)是一种基于网络的文件系统。它可以将远端服务器文件系统的目录挂载到本地文件系统的目录上,允许用户或者应用程序像访问本地文件系统的目录结构一样,访问远端服务器文件系统的目录结构,而无需理会远端服务器文件系统和本地文件系统的具体类型,非常方便地实现了目录和文件在不同机器上进行共享。虽然NFS不是唯一实现这个功能的文件系统,但它无疑是最成功一个。 NFS的第一个版本是SUN Microsystems在20世纪80年代开发出来的,至今为止,NFS经历了NFS,NFSv2,NFSv3和NFSv4共四个版本。现在,NFS最新的版本是4.1,也被称为pNFS(parallel NFS,并行网络文件系统)。 前四个版本的NFS,作为一个文件系统,它几乎具备了一个传统桌面文件系统最基本的结构特征和访问特征,不同之处在于它的数据存储于远端服务器上,而不是本地设备上,因此不存在磁盘布局的处理。NFS需要将本地操作转换为网络操 作,并在远端服务器上实现,最后返回操作的结果。因此,NFS更像是远端服务器文件系统在本地的一个文件系统代理,用户或者应用程序通过访问文件系统代理来访问真实的文件系统。 众所周知的是,NFS的客户端在访问远端服务器文件系统时,既需要通过服务器获得文件的属性信息,还需要通过服务器获得文件的数据信息,这使得NFS天然地具备将文件的属性信息和数据信息分离在不同服务器上进行访问的特性,于是最后一个版本NFS4.1/pNFS,将Lustre/CephFS/GFS等集群文件系统的设计思想引入到自身中,成为一个具有里程碑意义的NFS版本。它使得NFS的数据吞吐的速度和规模都得到了极大提高,为NFS的应用带了更为广阔的空间。 NFS之所以备受瞩目,除了它在文件共享领域上的优异表现外,还有一个关键原因在于它在NAS存储系统上应用。NAS与DAS和SAN在存储领域的竞争中,NFS发挥了积极的作用,这更使得NFS越来越值得关注。 NFSv3源代码结构 相比之前的两个版本,NFSv3是一个较为稳定和成熟的NFS版本,而之后的NFSv4除了在安全和性能上有所提高外,还在网络连接中加入了状态属性,因此显得复杂一些。在此,本文以NFSv3为例来剖析NFS文件系统的源代码结构,所用源码来自Linux 2.4.9内核。 按照NFS文件系统的设计与实现,NFS文件系统主要分为三个部分:The Protocol(网络协议),Client Side(NFS客户端)和Server Side(NFS服务器)。NFS客户端提供了接口,保证用户或者应用程序能像访问本地文件系统一样访问NFS 文件系统,NFS服务器作为数据源,为NFS客户端提供真实的文件系统服务,而网络协议则使得NFS客户端和NFS服务器能够高效和可靠地进行通信。NFS网络协议使用的是RPC(Remote Procedure Call,远程过程调用)/XDR(External Data Representation,外部数据表示)机制,因此本文将剖析的重点放在NFS客户端和NFS服务器上。 Client Side源代码 Client Side的头文件在include/linux/下面,C文件在fs/nfs下面。 ? dir.c/file.c/inode.c/symlink.c/unlink.c:与文件操作相关的系统调用 ? read.c/write.c/flushd.c:文件读写 ? mount_clnt.c/nfs_root.c:将NFS文件系统作为root目录的相关实现 ? proc.c/nfs2xdr.c/nfs3proc.c/nfs3xdr.c:网络数据交换 与文件操作相关的系统调用都在struct file_operations,struct inode_operations这两个数据结构里面定义。文件的读操作nfs_file_read和写操作nfs_file_write被单独提出来,因为文件读写性能将直接关系到文件

文档评论(0)

czy2014 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档