Linux中國

如何在 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

本文由 LCTT 原創編譯,Linux中國 榮譽推出


本文轉載來自 Linux 中國: https://github.com/Linux-CN/archive

對這篇文章感覺如何?

太棒了
0
不錯
0
愛死了
0
不太好
0
感覺很糟
0
雨落清風。心向陽

    You may also like

    Leave a reply

    您的郵箱地址不會被公開。 必填項已用 * 標註

    此站點使用Akismet來減少垃圾評論。了解我們如何處理您的評論數據

    More in:Linux中國