Linux下文件删除的原理
-
Lniux下控制文件真正被删除的计数器
Linux
是link
的数量来控制文件删除的。只有当一个文件不存在任何link的时候,这个文件才会被删除。一般来讲,每个文件都有两个link计数器:i_count
和i_link
-
i_count
的意义是当前文件使用者(或被调用)的数量
当一个文件被某一个进程引用时,对应的这个值就会增加 -
i_nlink
的意义是介质连接的数量(硬链接的数量)
当创建文件的硬链接的时候,这个值就会增加
可以理解为
i_count
是内存引用计数器,i_nlink
是硬盘的引用计数器 -
-
rm
命令原理对于删除命令
rm
而言,实际上就是减少磁盘引用计数i_nlink
。Q:如果一个文件正在被某个进程调用,而用户却执行
rm
把文件删除了,那么会出现什么结果?当用户执行rm
删除文件后,再执行ls
或其他文件管理命令,无法再找到这个文件了,但是调用这个删除的文件的进程却在继续正常执行,依然能够从文件中正确的读取及写入内容,这又是为什么呢?A:
rm
操作只是将文件的i_nlink
减少了,如果没有其它的链接i_nlink
就为0了。但是由于该文件依然被进程引用,因此,此时文件对应的i_count
并不为0,所以执行rm
操作,系统并没有真正的删除这个文件,只有当i_nlink
和i_count
都为0的时候,这个文件才会被真正的删除。也就是说,必须要解除该进程对该文件的调用,才能真正的删除。Q:当文件没有被调用,执行了
rm
操作之后,还能找回被删除的文件吗?A:
rm
操作只是将文件的i_nlink
减少了,或者说置为0,实际上就是将inode的链接删除了,此时,并没有删除文件的实体(block数据块),此时,如果及时停止机器工作,数据是可以找回的,如果继续写入数据,那么新数据可能会被分配到被删除的数据的block数据块,文件就被真正的回收了。 -
实际遇到的问题
Q:web服务器磁盘空间不够了,山除了所有无用日志还是显示磁盘空间不足,但是
du -sh
发现磁盘空间的占用率很小,这是为什么呢?是什么导致磁盘空间不足?A:删除命令只是删除了文件的一个
i_nlink
,但是其他进程正在使用这些log文件,apache
或tomat
,重启这些服务就好啦!