NFS协议端到端实例解析之写数据流程

网络 网络管理
服务端向RPC注册了各种回调函数,当接收到客户端的请求时会调用具体的回调函数进行处理。本例将调用nfsd3_proc_write函数。该函数最后调用VFS层的写数据函数,而VFS写数据函数则调用具体文件系统(例如Ext4)的函数完成最终的写数据操作。​

对于NFS来说,其写模式包含同步写,异步写和直接写等模式。模式的差异在于打开文件时指定的参数。限于篇幅,本文很难一一介绍所有模式,这里主要介绍一个核心流程。

NFS作为Linux下的文件系统,为了实现与VFS的对接,NFS也要实现一套函数指针接口。以文件相关的操作为例,其实现的函数指针如下所示。对于写数据来说,VFS会调用NFS的nfs_file_write函数。

图片图片

在该函数中,如果有SYNC标记则会触发同步写的流程,否则写入缓存后就会返回给调用者。本节我们主要关注触发同步写的流程,也就是数据是如何从NFS文件系统发送到服务端的。

直接写和同步写都会触发将数据发送到服务端的流程,本节以同步写为例介绍数据是如何发送到服务端的。如果触发同步刷写,那么会调用nfs_file_fsync函数,该函数是将缓存数据传输到服务端的入口。该函数到后端访问接口nfs_do_writepage的主线流程如下图所示。

图片图片

nfs_file_fsync主线流程

这里nfs_do_writepage用于将一个缓存页发送到服务端,具体实现如下代码所示。其中主要是功能由nfs_page_async_flush函数完成。这里比较重要的参数是pgio,在该参数中有页数据传输相关的函数指针,关于该参数类型的详细定义请参考内核源代码。

图片图片

然后我们再从nfs_page_async_flush函数开始计数看一下主线流程,具体下图所示。函数nfs_generic_pg_pgios就是在pgio初始化的函数指针,其在nfs_pageio_doio中被调用。该主线流程最终调用到nfs_initiate_pgio函数,该函数完成PRC消息和参数的封装,然后调用RPC服务的API函数完成请求。

nfs_page_async_flush主线流程nfs_page_async_flush主线流程

当nfs_initiate_pgio调用rpc_run_task函数后,整个流程就进入RPC服务内部了。也就是进入RPC服务状态机的流程了。关于RPC状态机的处理流程的介绍请参考本号相关内容。

最后,我们将整个写流程的简图展示一下,这里包括客户端的函数调用流程和服务端的处理流程。其中客户端的流程中省略了部分函数调用。

网络文件系统访问示意图网络文件系统访问示意图

服务端向RPC注册了各种回调函数,当接收到客户端的请求时会调用具体的回调函数进行处理。本例将调用nfsd3_proc_write函数。该函数最后调用VFS层的写数据函数,而VFS写数据函数则调用具体文件系统(例如Ext4)的函数完成最终的写数据操作。

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

2021-08-27 14:48:09

数据

2010-08-03 09:59:30

NFS服务

2023-08-08 09:52:13

系统端架构NFS

2010-01-20 16:12:16

2024-03-13 09:39:45

端到端自动驾驶

2023-02-16 08:00:00

数据流客户端开发数据集

2018-10-25 14:12:49

Oracle数据安全

2021-05-27 14:23:50

加密端到端加密加密技术

2021-06-30 09:00:00

测试Web软件

2020-10-26 13:51:11

Kafka数据端到端

2022-09-02 10:20:44

网络切片网络5G

2024-02-21 09:14:32

端到端自动驾驶

2009-06-27 20:32:00

LinuxNFS客户端

2024-03-29 09:32:03

模型训练

2011-04-22 09:25:37

思科数据中心交换矩阵融合技术

2023-08-14 08:17:13

Kafka服务端

2009-03-17 09:56:00

802.11n测试无线网络

2020-05-08 15:07:29

Zoom收购Keybase

2023-03-16 14:29:48

Vue.js测试

2024-03-04 09:51:41

自动驾驶特斯拉
点赞
收藏

51CTO技术栈公众号