問題現象html
一、執行 df -h 查看 ECS Linux 實例文件系統使用率,能夠看到 /dev/xvdb1 磁盤佔用了約27G,掛載目錄爲 /opt 。
二、進入到 /opt 目錄執行 du -sh ,顯示空間總佔用量約 2.4 G,即df 和du查看到的結果不一致。
linux
緣由分析服務器
du 命令對統計文件逐個進行 fstat 系統調用,獲取文件大小。它的數據是基於文件獲取,能夠跨多個分區操做。
df 命令使用 statfs 系統調用,直接讀取分區的超級塊信息獲取分區使用狀況。它的數據基於分區元數據,只能針對整個分區。
用戶刪除了大量的文件後,du 就不會在文件系統目錄中統計這些文件。若是此時還有運行中的進程持有這個已經被刪除的文件句柄,那麼這個文件就不會真正在磁盤中被刪除,分區超級塊中的信息也就不會更改,df 仍會統計這個被刪除的文件。
經過 lsof 查詢處於 deleted 狀態的文件,被刪除的文件在系統中被標記爲 deleted 。若是系統有大量 deleted 狀態的文件,會致使 du 和 df 統計結果不一致。
#lsof |grep deleted //在opt目錄下執行lsof |grep deleted3d
解決方案htm
一、根據 lsof 列出的 pid,kill 相應進程或者重啓相應的服務,如:#kill -9 692。blog
二、重啓服務器。重啓服務器系統會退出現有的進程,開機後從新加載,過程當中會釋放調用的 deleted 文件的句柄。進程