溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

linux下RM刪除文件空間釋放

發(fā)布時間:2021-08-30 15:44:36 來源:億速云 閱讀:188 作者:chen 欄目:建站服務器

本篇內容介紹了“l(fā)inux下RM刪除文件空間釋放”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!


產生一個指定大小的隨機內容文件

我們先看一下當前各個掛載目錄的空間大小:

$ df -h  
/dev/sda11      454M  280M  147M  66% /boot

我這里挑選了其中一個結果展示(你可以選擇任一掛載目錄),接下來準備在/boot下生成一個文件。

首先我們產生一個50M大小的文件:

$ dd if=/dev/urandom of=/boot/test.txt bs=50M count=1

至此,我們產生了一個50M大小的文件,再看boot下:

$ df -h  
/dev/sda11      454M  312M  115M  74% /boot

這里你不用關心到底多了多少,你只需要關注,/boot下的文件增多了。

測試程序:

#include  
#include  
int main(void)  
{  
    FILE *fp = NULL;  
    fp = fopen("/boot/test.txt", "rw+");  
    if(NULL == fp)  
    {  
       perror("open file failed");  
       return -1;  
    }  
    while(1)  
    {  
       //do nothing  
       sleep(1);  
    }  
    fclose(fp);  
    return 0;  
}

至于程序本身,也沒干啥實際的事情,就是打開一個文件,然后一直循環(huán)。編譯并運行:

$ gcc -o openFile openFile.c  
$ ./openFile

打開另外一個窗口,刪掉test.txt:

$ rm /boot/test.txt

再看一下boot空間:

$ df -h  
dev/sda11      454M  312M  115M  74% /boot

咦?空間大小怎么一點都沒變??!明明使用rm把它刪除了?。?/p>

我們把openFile程序停掉,再看看:

$$ df -h  
/dev/sda11      454M  280M  147M  66% /boot

乖乖,空間馬上就釋放掉了,也就是按照預期,我們的文件被刪除了。

一個文件什么情況下才會被刪除?

實際上,只有當一個文件的引用計數為0(包括硬鏈接數)的時候,才可能調用unlink刪除,只要它不是0,那么就不會被刪除。所謂的刪除,也不過是文件名到 inode 的鏈接刪除,只要不被重新寫入新的數據,磁盤上的block數據塊不會被刪除,因此,你會看到,即便刪庫跑路了,某些數據還是可以恢復的。換句話說,當一個程序打開一個文件的時候(獲取到文件描述符),它的引用計數會被+1,rm雖然看似刪除了文件,實際上只是會將引用計數減1,但由于引用計數不為0,因此文件不會被刪除。

struct inode {  
struct hlist_node   i_hash; /* hash鏈表的指針 */  
struct list_head    i_list; /* backing dev IO list */  
struct list_head    i_sb_list; /* 超級塊的inode鏈表 */  
struct list_head    i_dentry; /* 引用inode的目錄項對象鏈表頭 */  
unsigned long    i_ino; /* 索引節(jié)點號 */  
atomic_t         i_count; /* 引用計數 */  
unsigned int     i_nlink; /* 硬鏈接數目 */

關于里面的細節(jié),還有很多內容(如硬鏈接數量也會影響文件是否被刪除),這里不一一展開。

如何釋放已經被刪除文件占用的空間?

關于釋放,前面已經說了,重啟打開該文件的進程即可。但是有沒有方法找到哪些文件被刪除了,但還是被某些進程打開了呢?

自然是有方法的:

$ lsof |grep deleted

其中被標記為deleted的文件,就是這樣的一些文件。

其實在前面的例子中,我們也可以很容易觀察到(openFile程序運行,test.txt文件被刪除):

$ ls -al /proc/`pidof openFile`/fd  
total 0  
lrwx------ 1 root root 64 5月   4 09:27 0 -> /dev/pts/25  
lrwx------ 1 root root 64 5月   4 09:27 1 -> /dev/pts/25  
lrwx------ 1 root root 64 5月   4 09:27 2 -> /dev/pts/25  
lrwx------ 1 root root 64 5月   4 09:27 3 -> /boot/test.txt (deleted)

看見沒有,test.txt后面還有deleted字樣。

既然我們都說了,這樣的情況下文件是沒有被刪除的,那么還能不能恢復呢?實際上還是可以讀取的。

總結

實際上對于這種文件被刪除了,常常出現于程序的日志文件中,可能你有一個定時任務去清理程序產生的日志文件,但是如果程序本身忘記關閉句柄,就會導致磁盤空間得不到釋放,最終就是你認為文件都被刪除了,但是磁盤卻依然被占著。所以,養(yǎng)成好習慣,打開文件后,不用時,記得關閉文件描述符。

如果發(fā)現明明已經刪除了大量文件,但是空間卻并沒有恢復正常,那么不妨看看是不是還有程序打開了這些文件。

“l(fā)inux下RM刪除文件空間釋放”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI