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

2023年 8月 10日 61.0k 0

我们知道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文件系统的实现,后续我们会结合具体的流程深入到函数实现的细节。更多精彩内容还请关注本号。

相关文章

服务器端口转发,带你了解服务器端口转发
服务器开放端口,服务器开放端口的步骤
产品推荐:7月受欢迎AI容器镜像来了,有Qwen系列大模型镜像
如何使用 WinGet 下载 Microsoft Store 应用
百度搜索:蓝易云 – 熟悉ubuntu apt-get命令详解
百度搜索:蓝易云 – 域名解析成功但ping不通解决方案

发布评论