當系統的磁碟空間不足時,您可能會使用 df
、du
或 ncdu
命令進行檢查,但這些命令只會顯示當前目錄的檔案,並不會顯示整個系統範圍的檔案。
您得花費大量的時間才能用上述命令獲取系統中最大的檔案,因為要進入到每個目錄重複執行上述命令。
這種方法比較麻煩,也並不恰當。
如果是這樣,那麼該如何在 Linux 中找到最大的 10 個檔案呢?
我在谷歌上搜尋了很久,卻沒發現類似的文章,我反而看到了很多關於列出當前目錄中最大的 10 個檔案的文章。所以,我希望這篇文章對那些有類似需求的人有所幫助。
本教程中,我們將教您如何使用以下四種方法在 Linux 系統中查詢最大的前 10 個檔案。
方法 1
在 Linux 中沒有特定的命令可以直接執行此操作,因此我們需要將多個命令結合使用。
# find / -type f -print0 | xargs -0 du -h | sort -rh | head -n 10
1.4G /swapfile
1.1G /home/magi/ubuntu-17.04-desktop-amd64.iso
564M /home/magi/.gdfuse/magi/cache/0B5nso_FPaZFqTFU0XzkzUlJUZzA
378M /home/magi/.gdfuse/magi/cache/0B5nso_FPaZFqeldzUmhPeC03Zm8
377M /home/magi/.gdfuse/magi/cache/0B5nso_FPaZFqRGd4V0VrOXM4YVU
100M /usr/lib/x86_64-linux-gnu/libOxideQtCore.so.0
93M /usr/lib/firefox/libxul.so
84M /var/lib/snapd/snaps/core_3604.snap
84M /var/lib/snapd/snaps/core_3440.snap
84M /var/lib/snapd/snaps/core_3247.snap
詳解:
find
:在目錄結構中搜尋檔案的命令/
:在整個系統(從根目錄開始)中查詢-type
:指定檔案型別f
:普通檔案
-print0
:在標準輸出顯示完整的檔名,其後跟一個空字元(null)|
:控制運算子,將一條命令的輸出傳遞給下一個命令以供進一步處理xargs
:將標準輸入轉換成命令列引數的命令-0
:以空字元(null)而不是空白字元(LCTT 譯者注:即空格、製表符和換行)來分割記錄du -h
:以可讀格式計算磁碟空間使用情況的命令sort
:對文字檔案進行排序的命令-r
:反轉結果-h
:用可讀格式列印輸出head
:輸出檔案開頭部分的命令n -10
:列印前 10 個檔案
方法 2
這是查詢 Linux 系統中最大的前 10 個檔案的另一種方法。我們依然使用多個命令共同完成這個任務。
# find / -type f -exec du -Sh {} + | sort -rh | head -n 10
1.4G /swapfile
1.1G /home/magi/ubuntu-17.04-desktop-amd64.iso
564M /home/magi/.gdfuse/magi/cache/0B5nso_FPaZFqTFU0XzkzUlJUZzA
378M /home/magi/.gdfuse/magi/cache/0B5nso_FPaZFqeldzUmhPeC03Zm8
377M /home/magi/.gdfuse/magi/cache/0B5nso_FPaZFqRGd4V0VrOXM4YVU
100M /usr/lib/x86_64-linux-gnu/libOxideQtCore.so.0
93M /usr/lib/firefox/libxul.so
84M /var/lib/snapd/snaps/core_3604.snap
84M /var/lib/snapd/snaps/core_3440.snap
84M /var/lib/snapd/snaps/core_3247.snap
詳解:
find
:在目錄結構中搜尋檔案的命令/
:在整個系統(從根目錄開始)中查詢-type
:指定檔案型別f
:普通檔案
-exec
:在所選檔案上執行指定命令du
:計算檔案佔用的磁碟空間的命令-S
:不包含子目錄的大小-h
:以可讀格式列印{}
:遞迴地查詢目錄,統計每個檔案佔用的磁碟空間|
:控制運算子,將一條命令的輸出傳遞給下一個命令以供進一步處理sort
:對文字檔案進行按行排序的命令-r
:反轉結果-h
:用可讀格式列印輸出head
:輸出檔案開頭部分的命令n -10
:列印前 10 個檔案
方法 3
這裡介紹另一種在 Linux 系統中搜尋最大的前 10 個檔案的方法。
# find / -type f -print0 | xargs -0 du | sort -n | tail -10 | cut -f2 | xargs -I{} du -sh {}
84M /var/lib/snapd/snaps/core_3247.snap
84M /var/lib/snapd/snaps/core_3440.snap
84M /var/lib/snapd/snaps/core_3604.snap
93M /usr/lib/firefox/libxul.so
100M /usr/lib/x86_64-linux-gnu/libOxideQtCore.so.0
377M /home/magi/.gdfuse/magi/cache/0B5nso_FPaZFqRGd4V0VrOXM4YVU
378M /home/magi/.gdfuse/magi/cache/0B5nso_FPaZFqeldzUmhPeC03Zm8
564M /home/magi/.gdfuse/magi/cache/0B5nso_FPaZFqTFU0XzkzUlJUZzA
1.1G /home/magi/ubuntu-17.04-desktop-amd64.iso
1.4G /swapfile
詳解:
find
:在目錄結構中搜尋檔案的命令/
:在整個系統(從根目錄開始)中查詢-type
:指定檔案型別f
:普通檔案
-print0
:輸出完整的檔名,其後跟一個空字元(null)|
:控制運算子,將一條命令的輸出傳遞給下一個命令以供進一步處理xargs
:將標準輸入轉換成命令列引數的命令-0
:以空字元(null)而不是空白字元來分割記錄du
:計算檔案佔用的磁碟空間的命令sort
:對文字檔案進行按行排序的命令-n
:根據數字大小進行比較tail -10
:輸出檔案結尾部分的命令(最後 10 個檔案)cut
:從每行刪除特定部分的命令-f2
:只選擇特定欄位值-I{}
:將初始引數中出現的每個替換字串都替換為從標準輸入讀取的名稱-s
:僅顯示每個引數的總和-h
:用可讀格式列印輸出{}
:遞迴地查詢目錄,統計每個檔案佔用的磁碟空間
方法 4
還有一種在 Linux 系統中查詢最大的前 10 個檔案的方法。
# find / -type f -ls | sort -k 7 -r -n | head -10 | column -t | awk '{print $7,$11}'
1494845440 /swapfile
1085984380 /home/magi/ubuntu-17.04-desktop-amd64.iso
591003648 /home/magi/.gdfuse/magi/cache/0B5nso_FPaZFqTFU0XzkzUlJUZzA
395770383 /home/magi/.gdfuse/magi/cache/0B5nso_FPaZFqeldzUmhPeC03Zm8
394891761 /home/magi/.gdfuse/magi/cache/0B5nso_FPaZFqRGd4V0VrOXM4YVU
103999072 /usr/lib/x86_64-linux-gnu/libOxideQtCore.so.0
97356256 /usr/lib/firefox/libxul.so
87896064 /var/lib/snapd/snaps/core_3604.snap
87793664 /var/lib/snapd/snaps/core_3440.snap
87089152 /var/lib/snapd/snaps/core_3247.snap
詳解:
find
:在目錄結構中搜尋檔案的命令/
:在整個系統(從根目錄開始)中查詢-type
:指定檔案型別f
:普通檔案
-ls
:在標準輸出中以ls -dils
的格式列出當前檔案|
:控制運算子,將一條命令的輸出傳遞給下一個命令以供進一步處理sort
:對文字檔案進行按行排序的命令-k
:按指定列進行排序-r
:反轉結果-n
:根據數字大小進行比較head
:輸出檔案開頭部分的命令-10
:列印前 10 個檔案column
:將其輸入格式化為多列的命令-t
:確定輸入包含的列數並建立一個表awk
:模式掃描和處理語言'{print $7,$11}'
:只列印指定的列
via: https://www.2daygeek.com/how-to-find-search-check-print-top-10-largest-biggest-files-in-linux/
作者:Magesh Maruthamuthu 譯者:jessie-pang 校對:wxy
本文由 LCTT 原創編譯,Linux中國 榮譽推出