基于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;
	}
}

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

相关推荐
都在酒里12 小时前
Linux字符设备驱动开发(八):中断底半部——tasklet与工作队列实现按键消抖
linux·运维·驱动开发·交互
枳实-叶13 小时前
【Linux驱动开发】第17天:I2C子系统整体架构
linux·驱动开发·架构
智者知已应修善业14 小时前
【proteus仿真CD4511抢答器4路】2024-5-13
驱动开发·经验分享·笔记·硬件架构·proteus·硬件工程
枳实-叶1 天前
【Linux驱动开发】第16天:按键中断完整实战
linux·运维·驱动开发
都在酒里1 天前
Linux字符设备驱动开发(四):进入硬件世界——GPIO子系统与LED设备驱动
linux·运维·驱动开发
都在酒里1 天前
Linux字符设备驱动开发(五):PWM调光——实现LED亮度控制与呼吸灯效果
linux·运维·驱动开发
charlie1145141911 天前
嵌入式Linux驱动开发——设备树中的 GPIO 配置实战
linux·运维·驱动开发
都在酒里2 天前
Linux字符设备驱动开发(三):引入并发控制——使用mutex保护共享数据
linux·运维·驱动开发
都在酒里2 天前
Linux字符设备驱动开发(一):从零搭建一个可直接运行的驱动框架(附完整代码)
linux·运维·驱动开发