传统的nfs结构包括:一个共享文件系统的服务器端、一个挂载文件系统的客户端。存储器位于服务器端。当客户端想访问存储器上的文件时,要经过网络连接到服务器端,进而访问到文件,即带内访问。这样会受到带宽等因素的干扰,使性能收到影响。NFS 的最新许可版本是 NFS version 4。
NFS的下一个修改版本是version 4.1,包括一个扩展 Parallel NFS(pNFS)。它将普通 NFS 的优势和并行输入输出(I/O)的高传输率结合起来。它与NFS的区别在于,客户端、服务器均与存储器直接相连,客户端不必再通过服务器间接访问存储器了,即带外访问,再也不用收到带宽等因素的干扰,性能大大提高。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-0aoj5mib-1675403959476)(https://www.likecs.com/default/index/img?u=L2RlZmF1bHQvaW5kZXgvaW1nP3U9YUhSMGNITTZMeTl3YVdGdWMyaGxiaTVqYjIwdmFXMWhaMlZ6THpnNE15OWtNek00T1dZelptVTJOMlF3TjJObU9HSTBNRFZsT1RVMk1EZzJaR0psWWk1d2JtYz0= “NFS和pNFS”)]
上图显示一个 pNFS 配置。左边是pNFS服务器。顶部是客户机节点。底部是数据仓库,也就是存储器。
下面介绍图中三个协议:
我们通过read操作来看pNFS具体是怎么实现数据传输的。
布局可以缓存到客户机上,从而提高性能。为了避免布局过期,服务器将回收不准确的布局,当回收发生时,每个与之相关的客户机必须停止I/O,重新从服务器获取布局或从普通的NFS访问文件。当服务器进行数据迁移等操作之前,必须执行回收。