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,查看到被删除的文件,及其占用该文件的进程
![](https://img2022.cnblogs.com/blog/1651153/202210/1651153-20221025113053877-406739290.png)
通过该进程,进入到对应的/proc/nnnn/fd/目录,仍然可以找到对应的被删除文件
![](https://img2022.cnblogs.com/blog/955854/202205/955854-20220522211331693-2007947869.png)
这里就是关键了,可以使用 echo "" > file_name 命令将被删除的文件清空,直接缓解磁盘空间被占用的问题,之后有更多时间来处理这个问题。
![](https://img2022.cnblogs.com/blog/955854/202205/955854-20220522211341533-910686092.png)
当然这个方法也可以用来恢复被误删除的文件数据(仅限于被删除文件还被进程占用没有被完全释放)。