最近一项目涉及了对外置存储设备的读写,操作完成后应解除其挂载,但此时解除挂载失败。一般来说这种情况是某进程未正确释放其文件描述符导致的,可使用lsof
指令检查文件系统正在被哪些进程使用。
果然,lsof
显示该设备依然被一个曾对其进行读写的进程占用。Linux系统中,进程打开的文件描述符在/proc/[pid]/fd
目录下以链接的形式记录,但检查发现此处并没有那个被占用的设备。
反复检查程序后,确认每一个文件描述符都被妥善释放了,于是开始检查该进程调用的动态库。这时发现一个用于处理压缩文件的库在运行时改变了进程的工作目录,但在调用过程结束后没有切换回来。检查/proc/[pid]/cwd
目录,此处已不是该进程的启动目录,而恰好是那个被占用那个的设备中的目录。
在不修改动态库的情况下,一个简单的解决方案是在库函数调用后,使用chdir()
函数将该进程的工作目录复原,即可解除对设备的占用。
进程工作目录设置不当导致的设备持续被占用的问题
最新推荐文章于 2022-11-17 18:26:56 发布