Linux NFS文件系统端架构与代码解析

系统 Linux
本文主要从架构上来介绍NFS文件系统的实现,后续我们会结合具体的流程深入到函数实现的细节。更多精彩内容还请关注本号。

我们知道NFS分布式文件系统是一个客户端-服务端架构(CS架构)。其客户端是Linux内核中的一个文件系统,跟Ext4和XFS类似,差异在于其数据请求不存储在本地磁盘,而是通过网络发送到服务端进行处理。

图片图片

从上图所示的整体架构图上可以看出,NFS也是位于VFS下的文件系统。因此当NFS挂载后,其与本地文件系统并没有任何差异,用户在使用的时候也是透明的。

1NFS整体架构

作为VFS下的具体文件系统,NFS主要需要实现两套函数指针,对于文件(对于目录来说是另外的指针)来说前端实现了nfs_file_operations,用于适配VFS的调用。后端的接口实现则是nfs_file_aops,其用于实现与NFS服务端的通讯。

图片图片

2nfs_file_operations实现

nfs_file_operations的实现如下所示,可以看出这里实现了文件读写相关的函数接口,比如打开,读写,寻址和锁等等。

图片图片

以写数据为例,当用户调用write API时,首先会触发VFS的vfs_write函数,而该函数通过函数指针的方式调用nfs_file_write,具体如下所示。

图片图片

3nfs_file_aops实现

nfs_file_aops的具体实现如下所示,这里主要实现了如何将缓存页的数据通过网络发送到服务端,或者从服务端接收消息。其中nfs_writepags用于将缓存页发送到服务端。对于本地文件系统来说该函数的实现通常是将数据写入持久化的设备上。

图片图片

对于读数据来说通常是通过nfs_readpages,该函数则用于从远端设备读取数据。除此之外还有很多其它函数实现,本文不再赘述。

本文主要从架构上来介绍NFS文件系统的实现,后续我们会结合具体的流程深入到函数实现的细节。更多精彩内容还请关注本号。

责任编辑:武晓燕 来源: 数据存储张
相关推荐

2011-08-01 16:42:24

ibmdwNFS文件系统

2021-06-06 16:55:22

Linux文件系统

2009-12-02 16:16:33

linux系统

2009-12-25 08:50:46

NFS系统服务

2011-01-13 13:18:38

Linux网络文件

2009-11-26 11:31:34

NFS网络文件系统设定

2010-08-04 17:18:09

nfs文件系统

2010-08-06 12:42:23

NFS网络文件系统

2010-07-27 10:15:38

NFS网络文件系统

2010-08-03 11:32:30

NFS网络文件系统

2011-01-13 14:10:30

Linux文件系统

2023-08-21 08:31:40

LinuxNFSD架构

2020-07-22 14:53:06

Linux系统虚拟文件

2017-04-25 15:50:02

sparse传输处理

2010-04-13 13:31:31

Unix文件

2023-08-05 12:58:51

RPC协议服务端

2010-11-15 16:41:29

Oracle文件

2021-04-12 05:44:44

Linux文件系统

2018-08-24 10:10:25

Linux文件系统技术

2019-09-20 10:04:45

Linux系统虚拟文件
点赞
收藏

51CTO技术栈公众号