如何在 Linux 中查找最大的 10 個文件


當系統的磁盤空間不足時,您可能會使用 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


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM