面試官給我挖坑:rm刪除文件之后,空間就被釋放了嗎?
在Linux,你是不是曾經(jīng)天真的以為,使用rm刪除一個(gè)文件,占用的空間就釋放了?事情可能不是常常如人意。
產(chǎn)生一個(gè)指定大小的隨機(jī)內(nèi)容文件
我們先看一下當(dāng)前各個(gè)掛載目錄的空間大小:
df -h/dev/sda11 454M 280M 147M 66% /boot
我這里挑選了其中一個(gè)結(jié)果展示(你可以選擇任一掛載目錄),接下來(lái)準(zhǔn)備在/boot下生成一個(gè)文件。
首先我們產(chǎn)生一個(gè)50M大小的文件:
$ dd if=/dev/urandom of=/boot/test.txt bs=50M count=1至此,我們產(chǎn)生了一個(gè)50M大小的文件,再看boot下:
df -h/dev/sda11 454M 312M 115M 74% /boot
這里你不用關(guān)心到底多了多少,你只需要關(guān)注,/boot下的文件增多了。
測(cè)試程序:
int main(void){FILE *fp = NULL;fp = fopen("/boot/test.txt", "rw+");if(NULL == fp){perror("open file failed");return -1;}while(1){//do nothingsleep(1);}fclose(fp);return 0;}
至于程序本身,也沒(méi)干啥實(shí)際的事情,就是打開(kāi)一個(gè)文件,然后一直循環(huán)。編譯并運(yùn)行:
gcc -o openFile openFile.c./openFile
打開(kāi)另外一個(gè)窗口,刪掉test.txt:
rm /boot/test.txt再看一下boot空間:
df -hdev/sda11 454M 312M 115M 74% /boot
咦?空間大小怎么一點(diǎn)都沒(méi)變??!明明使用rm把它刪除了啊?
我們把openFile程序停掉,再看看:
$ df -h/dev/sda11 454M 280M 147M 66% /boot
乖乖,空間馬上就釋放掉了,也就是按照預(yù)期,我們的文件被刪除了。
一個(gè)文件什么情況下才會(huì)被刪除?
換句話說(shuō),當(dāng)一個(gè)程序打開(kāi)一個(gè)文件的時(shí)候(獲取到文件描述符),它的引用計(jì)數(shù)會(huì)被+1,rm雖然看似刪除了文件,實(shí)際上只是會(huì)將引用計(jì)數(shù)減1,但由于引用計(jì)數(shù)不為0,因此文件不會(huì)被刪除。
struct inode {struct hlist_node i_hash; /* hash鏈表的指針 */struct list_head i_list; /* backing dev IO list */struct list_head i_sb_list; /* 超級(jí)塊的inode鏈表 */struct list_head i_dentry; /* 引用inode的目錄項(xiàng)對(duì)象鏈表頭 */unsigned long i_ino; /* 索引節(jié)點(diǎn)號(hào) */atomic_t i_count; /* 引用計(jì)數(shù) */unsigned int i_nlink; /* 硬鏈接數(shù)目 */
關(guān)于里面的細(xì)節(jié),還有很多內(nèi)容(如硬鏈接數(shù)量也會(huì)影響文件是否被刪除),這里不一一展開(kāi)。
如何釋放已經(jīng)被刪除文件占用的空間?
關(guān)于釋放,前面已經(jīng)說(shuō)了,重啟打開(kāi)該文件的進(jìn)程即可。但是有沒(méi)有方法找到哪些文件被刪除了,但還是被某些進(jìn)程打開(kāi)了呢?
自然是有方法的:
lsof |grep deleted其中被標(biāo)記為deleted的文件,就是這樣的一些文件。
其實(shí)在前面的例子中,我們也可以很容易觀察到(openFile程序運(yùn)行,test.txt文件被刪除):
$ ls -al /proc/`pidof openFile`/fdtotal 0lrwx------ 1 root root 64 5月 4 09:27 0 -> /dev/pts/25lrwx------ 1 root root 64 5月 4 09:27 1 -> /dev/pts/25lrwx------ 1 root root 64 5月 4 09:27 2 -> /dev/pts/25lrwx------ 1 root root 64 5月 4 09:27 3 -> /boot/test.txt (deleted)
看見(jiàn)沒(méi)有,test.txt后面還有deleted字樣。
既然我們都說(shuō)了,這樣的情況下文件是沒(méi)有被刪除的,那么還能不能恢復(fù)呢?實(shí)際上還是可以讀取的。
總結(jié)
如果發(fā)現(xiàn)明明已經(jīng)刪除了大量文件,但是空間卻并沒(méi)有恢復(fù)正常,那么不妨看看是不是還有程序打開(kāi)了這些文件。
來(lái)源:編程珠璣
版權(quán)申明:內(nèi)容來(lái)源網(wǎng)絡(luò),版權(quán)歸原創(chuàng)者所有。除非無(wú)法確認(rèn),我們都會(huì)標(biāo)明作者及出處,如有侵權(quán)煩請(qǐng)告知,我們會(huì)立即刪除并表示歉意。謝謝!

