如何在 Linux 中查詢最大的 10 個檔案

16 贊 回覆發表於2018-03-30

當系統的磁碟空間不足時,您可能會使用 dfduncdu 命令進行檢查,但這些命令只會顯示當前目錄的檔案,並不會顯示整個系統範圍的檔案。

您得花費大量的時間才能用上述命令獲取系統中最大的檔案,因為要進入到每個目錄重複執行上述命令。

這種方法比較麻煩,也並不恰當。

如果是這樣,那麼該如何在 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中國 榮譽推出

相關文章