客戶反映云主機(jī)數(shù)據(jù)盤就放了幾個網(wǎng)站,可是統(tǒng)計資源占用了90%以上的空間。如下圖,df統(tǒng)計數(shù)據(jù)盤已使用35G,可是du統(tǒng)計出來的數(shù)據(jù)不足10G。
問題原因
用戶刪除了大量的文件后,du命令就不會在文件系統(tǒng)目錄中統(tǒng)計這些文件。如果此時還在運(yùn)行中的進(jìn)程持有這個已經(jīng)被刪除的文件句柄,那么這個文件就不會真正在磁盤中被刪除,分區(qū)超級塊中的信息也就不會更改,df命令仍會統(tǒng)計這個被刪除的文件。 通過lsof命令查詢處于deleted狀態(tài)的文件,被刪除的文件在系統(tǒng)中被標(biāo)記為deleted。如果系統(tǒng)有大量deleted狀態(tài)的文件,會導(dǎo)致du和df命令統(tǒng)計結(jié)果不一致。
可執(zhí)行如下命令查看lsof |grep deleted
解決方法
根據(jù)lsof列出的進(jìn)程號,終止相應(yīng)進(jìn)程或者重啟相應(yīng)的服務(wù)。也可以重啟實例,重啟實例系統(tǒng)會退出現(xiàn)有的進(jìn)程,開機(jī)后重新加載過程中,會釋放調(diào)用的deleted文件的句柄。