作为自动VM创建系统的一部分,块设备被安装到临时文件夹(/ tmp / whatever).各种脚本在首次运行之前安装和配置VM.
最近有些事情发生了变化,临时坐骑很忙,拒绝下车.在尝试确定可能仍然保持文件打开的时候我已经检查过:
测试以root身份运行
>坐骑@H_403_7@> lsof | grep / tmp /@H_403_7@> fuser -m / tmp / …@H_403_7@> exportfs -rv@H_403_7@>重新启动运行创建脚本的守护进程……@H_403_7@> ps axf@H_403_7@> dmsetup表@H_403_7@> losetup -a@H_403_7@> fuser -vm /tmp/tmp.random-chars/(产生两行)@H_403_7@>@H_403_7@>用户PID访问命令
>@H_403_7@> /tmp/tmp.random-chars:root kernel mount /tmp/tmp.random-chars
上述测试都没有指向文件系统使用的结果,但是umount -f仍然抱怨“设备或资源忙”/“设备忙”.
我应该尝试哪些其他测试,以便我可以找到真正的根本原因,从而有希望在没有重新启动系统的情况下修复卡住的挂载,我现在无法重启一段时间以及防止这种情况再次发生?
由于临时安装的Linux安装版本与主机运行的版本不同,因此也可以/(但我不知道如何检查)加载临时安装的内核模块.
编辑
>从各种搜索结果看来,/ modules /只是简单地读入内存.我不知道内核是否可以打开文件以及如何访问任何此类列表.@H_403_7@>将dmsetup / losetup添加到“未显示问题的测试”列表中@H_403_7@> freenode ## linux中建议的fuser -vm
解决方法
如果它是构建过程的一部分,我假设你无论如何都需要重新启动.尝试在进程中插入“懒惰”卸载.使用umount -l / tmp,看看是否有助于您在此过程中超越此障碍.