FUSE使用总结

1.FUSE简介

由于近期一个项目用到FUSE实现一个文件系统,所以有一些使用FUSE的经验。现总结如下:

FUSE(Filesystem in Userspace)是一个开源项目,它可以为用户提供编写用户态文件系统的接口。

运行架构如下:

image.png

2.性能消耗

从架构图可知,用户进程userd访问文件系统userfsd时,需要先从用户态进入内核态,再从内核态到用户态,结果返回时也是从用户态进入内核态,再从内核态到用户态,数据需要多次拷贝。从我们的测试结果看FUSE占用的cpu是整个userfsd占用的cpu的30%左右。

3.业务处理不支持固定的线程池

FUSE的处理每个请求时会从预留的线程里找是否有空闲的线程,如果没有就会起新的线程来响应请求。这种处理方式导致为了避免频繁起新的线程需要将保留idle线程的参数max_idle_threads设的比较大,但这个值比较大时,线程之间的切换开销也不小。

4.启动参数auto_unmount有缺陷

使用auto_unmount启动参数会让userfsd fork一个叫fusermount3的进程,但userfsd在代码里没有调用waitpid,这样编码的话,fusermount3异常退出的时候容易产生僵尸进程; 不过只退了fusermount3, 还不影响dbfsd的功能,但如果这个时候dbfsd也发生异常退出的话,挂载点目录就用不了,需要手工处理。

同时如果使用该参数,在非root用户启动userfsd时需要赋予fusermount3管理权限。所以建议不使用该参数。

5.文件被打开时该文件被删除

FUSE有个硬删除的选项,需要代码指定,缺省是false。如果这个选项设置成true,则即使该文件被一个进程打开了,另外进程也可以直接删除,如果这是正在进行写操作就会直接返回错误。如果这个选项设置成false,则在进程删除文件时,如果这个被打开了,就会将这个文件rename成一个隐藏文件,待打开这个文件的进程把它关闭了才把隐藏文件删除。

6.在非root用户下启动

为了安全考虑一般需要将用户态文件系统进程userfsd起在非root用户下,FUSE支持这种场景。userfsd可以指定allow_other启动选项,同时需要执行”echo user_allow_other >> fuse.conf”命令将user_allow_other放到fuse.conf配置文件里,这样userfsd就可以起在非root用户下了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值