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

吾爱主题 阅读:231 2024-04-05 15:08:32 评论: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文件系统的实现,后续我们会结合具体的流程深入到函数实现的细节。更多精彩内容还请关注本号。

可以去百度分享获取分享代码输入这里。
声明

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

【腾讯云】云服务器产品特惠热卖中
搜索
标签列表
    关注我们

    了解等多精彩内容