Linux df和du命令查出來的已使用空間不同如何解決?
有用戶登錄到Linux系統服務器上查看的時候,竟然發現df和du查出來的結果不一樣,du查出來的“實際使用空間”明顯比df查出來的已使用空間要小很多,這是究竟是怎么一回事呢?難道有些空間被隱藏起來了?下面來說一下df和du命令查出來的已使用空間不同的解決方法。
方法如下:
首先,我們用df來查看已使用空間:

從上圖可知,根分區已使用5456700KB(合約5.20GB)。
然后,我們用du查出根分區下每個目錄的大小:

排除紅框中的兩個目錄(因為他們是掛載上去的),所有目錄的總大小為3075332KB(合約2.93GB),比df查出來足足小了2.27GB。
為什么會少了這么多空間呢?
其實是因為我們之前刪除了一些進程正在寫入的文件,雖然已經被我們刪除了,但只要進程還在,那個文件就不會被真正地刪除,只是被臨時存放到系統的某個地方而已,有點類似于Windows的回收站。
想解決這個問題,最簡單地就是重啟服務器了,但是生產環境一般都不會輕易重啟的,所以我們可以通過其他方式來解決。
先用lsof命令配合grep命令查出哪些是已經被刪除,卻依舊占用系統空間的“無賴”。

上圖紅框中的文件正是我之前刪除的一個大文件,我現在嘗試去重啟這個程序(node),我直接kill掉這個進程,因為我做了自動啟動,所以我不用手動去啟動它。

已使用空間一下子下降到3226324KB(合約3.08GB),已經很接近du統計的總空間了。
接下來,我逐個重啟了其他deleted的文件,最終df查出來的大小就和du統計的總空間差不多大了。
到此,就解決了df和du查出來的結果不同的文件,趕走了系統里的“無賴”,索回屬于我們的空間。
df和du命令查出來的已使用空間不同的解決方法就說到這里了,如你們也有此問題的可以按照上述的步驟去操作,從而解決問題。
相關文章:
1. 如何重裝windows10官網系統?windows10官網重裝系統操作圖文教程2. WmiPrvSE.exe是什么進程?WMI Provider Host占用很高CPU的解決方法3. Centos7安裝Chacha20加密算法詳解4. secbizsrv.exe是什么進程(支付寶安全控件)5. 如何在硬件不受支持的 PC 上安裝 Windows116. 基于 Ubuntu 的 elementary OS 7 版本發布 附官方下載7. 12個注冊表優化方法有助于提高電腦的開關機速度及上網速度8. 統信UOS系統怎么關閉? uos關機的多種方法9. 360se.exe進程介紹 360se.exe進程占用CPU過高原因有哪些10. 基于 Ubuntu 20.04 LTS,KDE neon 20221222 版本發布
