linux删除文件后,但空间未释放解决办法

linux系统下文件被删除之后,使用df命令查看,磁盘空间却没有被释放,怎么排查?

其实磁盘空间没有释放是有进程仍在占用被删除的文件,要想真正的删除,只需要停止或重启进程,释放进程对文件的占用即可。

但是如果这个程序很重要,不能被停止,该怎么处理呢?

在Linux或者Unix系统中,通过rm或者文件管理器删除文件将会从文件系统的目录结构上解除链接(unlink)。然而如果文件是被打开的(有一个进程正在使用),那么进程将仍然可以读取该文件,磁盘空间也一直被占用。
 
一种解决方法是kill掉相应的进程,或者停掉使用这个文件的应用,让os自动回收磁盘空间。这种方法就像后面面试官追问的那样,停掉或重启应用风险较大。那么还有什么方法能解决吗?
 
从更深一层次来看,当linux打开一个文件的时候,Linux内核会为每一个进程在/proc/ 『/proc/nnnn/fd/目录(nnnn为pid)』建立一个以其pid为名的目录用来保存进程的相关信息,而其子目录fd保存的是该进程打开的所有文件的fd(fd:file descriptor)。
 
当文件被删除后,从文件目录上已经看不到了,但是还可以使用lsof命令:lsof |grep deleted,查看到被删除的文件,及其占用该文件的进程

 

通过该进程,进入到对应的/proc/nnnn/fd/目录,仍然可以找到对应的被删除文件

 
这里就是关键了,可以使用 echo "" > file_name 命令将被删除的文件清空,直接缓解磁盘空间被占用的问题,之后有更多时间来处理这个问题。
 
当然这个方法也可以用来恢复被误删除的文件数据(仅限于被删除文件还被进程占用没有被完全释放)。
posted @ 2022-10-25 11:32  玩转大数据  阅读(8909)  评论(0编辑  收藏  举报