exfat文件系统无法NFS导出的问题

2024-06-16 23:12

本文主要是介绍exfat文件系统无法NFS导出的问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

        最近项目中移植了exfat-linux驱动,但发现exfat格式的U盘无法用exportfs命令在NFS上导出。这篇文章记录了分析、解决方法。

一、问题现象

问题描述:exfat驱动更新后,exfat格式的U盘用exportfs命令NFS导出会报错

$ exportfs -o ro,fsid=0,no_root_squash 192.168.100.74:/storage/9CE5-DFCB/Carlog

报错:"does not support NFS export"


问题原因:

        文件系统要被export必须满足两个条件:第一要有唯一标识,可以是fsid,uuid或者是设备号,第二是文件系统必须设置了export操作集 export_operations。第一个条件可以通过exportfs或在/etc/exports文件中指定fsid的值来满足,第二个条件需要文件系统源代码定义了export_operations

        在exfat-linux驱动源码 fs/exfat/super.c 未定义 export_operations,因此所以exfat文件系统导出NFS会报错。

二、分析过程及思考

1、exportfs命令介绍

        exportfs是Linux中的一个命令,用于将指定的目录或文件系统在NFS上导出,从而实现文件系统的共享和访问控制,通过NFS协议允许其他计算机通过网络访问共享文件。

具体来说,exportfs的作用包括:

  • 共享文件系统:通过exportfs命令,可以将文件系统或目录共享给其他计算机。这样,其他计算机就可以通过NFS协议挂载该共享文件系统,实现文件的共享和访问。
  • 访问权限控制:exportfs命令可以设置文件系统的访问权限,包括读写权限和只读权限。通过配置exportfs,可以控制哪些计算机可以访问共享文件系统以及访问权限的级别。
  • 配置NFS服务:exportfs命令是NFS服务的一部分,通过该命令可以将指定的目录或文件系统添加到NFS服务的导出列表中,从而启用NFS服务并提供共享。

2、分析过程

        首先看下 linux/include/linux/exportfs.h 文档,其中提到 export_operations,详细使用 export_operations 方法需阅读 Documentation/filesystems/nfs/exporting.rst 文档。

      linux/Documentation/filesystems/nfs/exporting.rst 文档,其中有一段:

A file system implementation declares that instances of the filesystem
are exportable by setting the s_export_op field in the struct
super_block.  This field must point to a "struct export_operations"
struct which has the following members:encode_fh  (optional)Takes a dentry and creates a filehandle fragment which can later be usedto find or create a dentry for the same object.  The defaultimplementation creates a filehandle fragment that encodes a 32bit inodeand generation number for the inode encoded, and if necessary thesame information for the parent.fh_to_dentry (mandatory)Given a filehandle fragment, this should find the implied object andcreate a dentry for it (possibly with d_obtain_alias).fh_to_parent (optional but strongly recommended)Given a filehandle fragment, this should find the parent of theimplied object and create a dentry for it (possibly withd_obtain_alias).  May fail if the filehandle fragment is too small.

        文件系统导出功能可通过设置 super_block 中的 s_export_op 字段实现。s_export_op 字段必须指向 "struct export_operations"。

        可以看到,exfat-linux驱动源码 fs/exfat/super.c 并未定义 export_operations,因此NFS导出会失败。

3、解决方法

        将老exfat驱动中 s_export_op 相关代码移植到 exfat-linux驱动源码 fs/exfat/super.c 中,方法如下:

 添加 linux/exportfs.h 头文件

#include <linux/exportfs.h>

定义 struct export_operations 结构体

/*======================================================================*/
/*  Export Operations                                                   */
/*======================================================================*/static struct inode *exfat_nfs_get_inode(struct super_block *sb,u64 ino, u32 generation)
{struct inode *inode = NULL;if (ino < EXFAT_ROOT_INO)return inode;inode = ilookup(sb, ino);if (inode && generation && (inode->i_generation != generation)) {iput(inode);inode = NULL;}return inode;
}static struct dentry *exfat_fh_to_dentry(struct super_block *sb, struct fid *fid,int fh_len, int fh_type)
{return generic_fh_to_dentry(sb, fid, fh_len, fh_type,exfat_nfs_get_inode);
}static struct dentry *exfat_fh_to_parent(struct super_block *sb, struct fid *fid,int fh_len, int fh_type)
{return generic_fh_to_parent(sb, fid, fh_len, fh_type,exfat_nfs_get_inode);
}const struct export_operations exfat_export_ops = {.fh_to_dentry   = exfat_fh_to_dentry,.fh_to_parent   = exfat_fh_to_parent,
};

         s_export_op 指向 struct export_operations 结构体。exfat_fill_super() 函数中添加 sb->s_export_op = &exfat_export_ops;

static int exfat_fill_super(struct super_block *sb, void *data, int silent)
{struct exfat_sb_info *sbi;struct exfat_mount_options *opts;struct inode *root_inode;int err;err = exfat_init_sb_info(sb);if (err) {exfat_err(sb, "failed to initialize superblock info");goto failed;}sbi = sb->s_fs_info;opts = &sbi->options;sb->s_flags |= SB_NODIRATIME;sb->s_magic = EXFAT_SUPER_MAGIC;sb->s_op = &exfat_sops;sb->s_export_op = &exfat_export_ops;。。。 。。。
}

代码下载链接:https://download.csdn.net/download/hinewcc/89440534

说明:相关修改请看super.c文件!!!

修改后,重新编译kernel 运行 NFS 导出功能正常!

4、参考文档

Kernel File Handle 详解 - liuchao719 - 博客园 (cnblogs.com)

【linux3.10】【nfs】使文件系统可导出_linuxnfs导出文件-CSDN博客

jffs2文件系统不支持export的问题_sonfs-CSDN博客

这篇关于exfat文件系统无法NFS导出的问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1067819

相关文章

linux下多个硬盘划分到同一挂载点问题

《linux下多个硬盘划分到同一挂载点问题》在Linux系统中,将多个硬盘划分到同一挂载点需要通过逻辑卷管理(LVM)来实现,首先,需要将物理存储设备(如硬盘分区)创建为物理卷,然后,将这些物理卷组成... 目录linux下多个硬盘划分到同一挂载点需要明确的几个概念硬盘插上默认的是非lvm总结Linux下多

Python Jupyter Notebook导包报错问题及解决

《PythonJupyterNotebook导包报错问题及解决》在conda环境中安装包后,JupyterNotebook导入时出现ImportError,可能是由于包版本不对应或版本太高,解决方... 目录问题解决方法重新安装Jupyter NoteBook 更改Kernel总结问题在conda上安装了

pip install jupyterlab失败的原因问题及探索

《pipinstalljupyterlab失败的原因问题及探索》在学习Yolo模型时,尝试安装JupyterLab但遇到错误,错误提示缺少Rust和Cargo编译环境,因为pywinpty包需要它... 目录背景问题解决方案总结背景最近在学习Yolo模型,然后其中要下载jupyter(有点LSVmu像一个

解决jupyterLab打开后出现Config option `template_path`not recognized by `ExporterCollapsibleHeadings`问题

《解决jupyterLab打开后出现Configoption`template_path`notrecognizedby`ExporterCollapsibleHeadings`问题》在Ju... 目录jupyterLab打开后出现“templandroidate_path”相关问题这是 tensorflo

如何解决Pycharm编辑内容时有光标的问题

《如何解决Pycharm编辑内容时有光标的问题》文章介绍了如何在PyCharm中配置VimEmulator插件,包括检查插件是否已安装、下载插件以及安装IdeaVim插件的步骤... 目录Pycharm编辑内容时有光标1.如果Vim Emulator前面有对勾2.www.chinasem.cn如果tools工

最长公共子序列问题的深度分析与Java实现方式

《最长公共子序列问题的深度分析与Java实现方式》本文详细介绍了最长公共子序列(LCS)问题,包括其概念、暴力解法、动态规划解法,并提供了Java代码实现,暴力解法虽然简单,但在大数据处理中效率较低,... 目录最长公共子序列问题概述问题理解与示例分析暴力解法思路与示例代码动态规划解法DP 表的构建与意义动

Java多线程父线程向子线程传值问题及解决

《Java多线程父线程向子线程传值问题及解决》文章总结了5种解决父子之间数据传递困扰的解决方案,包括ThreadLocal+TaskDecorator、UserUtils、CustomTaskDeco... 目录1 背景2 ThreadLocal+TaskDecorator3 RequestContextH

关于Spring @Bean 相同加载顺序不同结果不同的问题记录

《关于Spring@Bean相同加载顺序不同结果不同的问题记录》本文主要探讨了在Spring5.1.3.RELEASE版本下,当有两个全注解类定义相同类型的Bean时,由于加载顺序不同,最终生成的... 目录问题说明测试输出1测试输出2@Bean注解的BeanDefiChina编程nition加入时机总结问题说明

关于最长递增子序列问题概述

《关于最长递增子序列问题概述》本文详细介绍了最长递增子序列问题的定义及两种优化解法:贪心+二分查找和动态规划+状态压缩,贪心+二分查找时间复杂度为O(nlogn),通过维护一个有序的“尾巴”数组来高效... 一、最长递增子序列问题概述1. 问题定义给定一个整数序列,例如 nums = [10, 9, 2

Spring AI Alibaba接入大模型时的依赖问题小结

《SpringAIAlibaba接入大模型时的依赖问题小结》文章介绍了如何在pom.xml文件中配置SpringAIAlibaba依赖,并提供了一个示例pom.xml文件,同时,建议将Maven仓... 目录(一)pom.XML文件:(二)application.yml配置文件(一)pom.xml文件:首