基于FUSE的文件系统过滤驱动开发方法

Fuse框架可以直接在用户层挂载一个自定义的文件系统,当将挂载点和挂载内容重叠在一起时就形成了一个文件系统过滤层,如fuse mount ~/A to ~/A

此时可以借助挂载命名空间方式在fuse程序内访问原始文件系统,避免递归回fuse(这样回死锁)

cpp 复制代码
int main(int argc, char *argv[])
{
	try
	{
		// 解析命令行参数<tool> watchingdir
		if (argc < 2)
		{
			std::cerr << "Usage: " << argv[0] << " watchingdir <mount-point>" << std::endl;
			return 1;
		}

		g_Ori_euid = geteuid();
		g_Ori_egid = getegid();

		std::string mount_point = argv[1];
		std::string watch_dir = mount_point;

		int ur = fuse_unmount(mount_point.c_str(), 1);
		printf("ur=%d,%d\n", ur, errno);

		//备份当前的挂载命名空间
		// 1. 保存当前挂载命名空间
		original_mnt_ns_fd = open("/proc/self/ns/mnt", O_RDONLY);
		if (original_mnt_ns_fd == -1)
		{
			perror("open original mnt ns failed");
			exit(EXIT_FAILURE);
		}

		// 2. 创建新的挂载命名空间
		if (unshare(CLONE_NEWNS) == -1)
		{
			perror("unshare failed");
			exit(EXIT_FAILURE);
		}

		// 3. 在新命名空间中挂载根文件系统为私有
		if (mount("/", "/", NULL, MS_REC | MS_PRIVATE, NULL) == -1)
		{
			perror("mount private failed");
			exit(EXIT_FAILURE);
		}
		//备份新命名空间fd
		new_mnt_ns_fd = open("/proc/self/ns/mnt", O_RDONLY);
		if (new_mnt_ns_fd == -1)
		{
			perror("open original mnt ns failed");
			exit(EXIT_FAILURE);
		}
		//切换到原来的空间
		if (0 != switch_namespace(original_mnt_ns_fd))
		{
			perror("switch old");
			exit(EXIT_FAILURE);
		}

		// 创建FuseWatcher实例
		FuseWatcher watcher(watch_dir);

		// 挂载FUSE文件系统
		int ret = watcher.mount(argc, argv);

		if (ret != 0)
		{
			std::cerr << "Failed to mount FUSE filesystem: " << ret << std::endl;
			return ret;
		}

		return 0;
	}
	catch (const std::exception &e)
	{
		std::cerr << "Error: " << e.what() << std::endl;
		return 1;
	}
}

之后在回调时就可以切换命名空间进行访问,也可以模拟调用者身份进行访问,此时默认可以做到一个透明转发的功能,再进行修改就可以完成文件审计功能

相关推荐
世微 如初2 天前
AP5125大功率LED恒流驱动实战:地摊灯项目从原理图到调试笔记
驱动开发·芯片·led电源驱动·降压恒流ic
ScilogyHunter2 天前
Zephyr串口驱动开发及构建完全指南
驱动开发·uart·zephyr
_Emma_2 天前
【DRM&Graphic】Linux图形与显示框架
linux·驱动开发·图形渲染·显示器
董厂长2 天前
Loop Engineering:停止手动提示,开始设计自动提示的系统
大数据·人工智能·驱动开发·llm
Saniffer_SH3 天前
【高清视频】Gen6 服务器还没到,Gen6 SSD 怎么测?Emily 现场演示三种测试环境
人工智能·驱动开发·测试工具·缓存·fpga开发·计算机外设·压力测试
暮云星影3 天前
全志linux开发屏幕适配(二)`HDMI`驱动适配说明
linux·arm开发·驱动开发
charlie1145141913 天前
嵌入式Linux驱动开发——从轮询到中断
linux·开发语言·驱动开发·嵌入式
暮云星影3 天前
瑞芯微rk3566开发FIT Secure Boot
linux·arm开发·驱动开发·安全
暮云星影3 天前
全志linux开发 USB接口设置
linux·arm开发·驱动开发
sukalot3 天前
windows显示驱动开发-CCD DDI的其它技术
windows·驱动开发