萬盛學電腦網

 萬盛學電腦網 >> Linux教程 >> Linux df和du命令查出來的已使用空間不同如何解決?

Linux df和du命令查出來的已使用空間不同如何解決?

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

  方法如下:

  首先,我們用df來查看已使用空間:

Linux df和du命令查出來的已使用空間不同如何解決?

  從上圖可知,根分區已使用5456700KB(合約5.20GB)。

  然後,我們用du查出根分區下每個目錄的大小:

Linux df和du命令查出來的已使用空間不同如何解決?

  排除紅框中的兩個目錄(因為他們是掛載上去的),所有目錄的總大小為3075332KB(合約2.93GB),比df查出來足足小了2.27GB。

  為什麼會少了這麼多空間呢?

  其實是因為我們之前刪除了一些進程正在寫入的文件,雖然已經被我們刪除了,但只要進程還在,那個文件就不會被真正地刪除,只是被臨時存放到系統的某個地方而已,有點類似於Windows的回收站。

  想解決這個問題,最簡單地就是重啟服務器了,但是生產環境一般都不會輕易重啟的,所以我們可以通過其他方式來解決。

  先用lsof命令配合grep命令查出哪些是已經被刪除,卻依舊占用系統空間的“無賴”。

Linux df和du命令查出來的已使用空間不同如何解決?

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

Linux df和du命令查出來的已使用空間不同如何解決?

  已使用空間一下子下降到3226324KB(合約3.08GB),已經很接近du統計的總空間了。

  接下來,我逐個重啟了其他deleted的文件,最終df查出來的大小就和du統計的總空間差不多大了。

  到此,就解決了df和du查出來的結果不同的文件,趕走了系統裡的“無賴”,索回屬於我們的空間。

  df和du命令查出來的已使用空間不同的解決方法就說到這裡了,如你們也有此問題的可以按照上述的步驟去操作,從而解決問題。

copyright © 萬盛學電腦網 all rights reserved