在Windows系统中,我们可以使用TreeSize工具查找一些大文件或文件夹,非常的方便高效,在Linux系统中,如何去搜索一些比较大的文件呢?下面我整理了一下在Linux系统中如何查找大文件或文件夹的方法。

1: 如何查找大文件?

其实很多时候,你需要了解当前系统下有哪些大文件,比如文件大小超过100M或1G(阀值视具体情况而定)。那么如何把这些大文件搜索出来呢?例如我要搜索当前目录下,超过800M大小的文件

  1. [root@getlnx01 u03]# pwd

  1. /u03

  1. [root@getlnx01 u03]# find . -type f -size +800M

  1. ./flash_recovery_area/backup/backupsets/ora_df873519197_s46815_s1

  1. ./flash_recovery_area/backup/backupsets/ora_df873523646_s46822_s1

  1. ./flash_recovery_area/backup/backupsets/ora_df873521714_s46818_s1

  1. ./flash_recovery_area/backup/backupsets/ora_df873522876_s46820_s1

  1. ./flash_recovery_area/backup/backupsets/ora_df873517396_s46813_s1

  1. ./flash_recovery_area/backup/backupsets/ora_df873523321_s46821_s1

  1. ./flash_recovery_area/backup/backupsets/ora_df873515765_s46811_s1

  1. ./flash_recovery_area/backup/backupsets/ora_df873520789_s46817_s1

  1. ./flash_recovery_area/backup/backupsets/ora_df873524162_s46823_s1

  1. ./flash_recovery_area/backup/backupsets/ora_df873518302_s46814_s1

  1. ./flash_recovery_area/backup/backupsets/ora_df873519953_s46816_s1

  1. ./flash_recovery_area/backup/backupsets/ora_df873516500_s46812_s1

  1. ./flash_recovery_area/backup/backupsets/ora_df873513413_s46809_s1

  1. ./flash_recovery_area/backup/backupsets/ora_df873514789_s46810_s1

  1. ./oradata/epps/invsubmat_d08.dbf

  1. ./oradata/epps/gmtinv_d08.dbf

  1. ./oradata/epps/gmtinv_x01.dbf

  1. ./oradata/epps/undotbs02.dbf

  1. ./oradata/epps/gmtinv_d07.dbf

  1. ./oradata/epps/undotbs01.dbf

  1. ./oradata/epps/gmtinv_x02.dbf

如上命令所示,我们仅仅能看到超过800M大小的文件的文件名称,但是对文件的信息(例如,文件大小、文件属性)一无所知,那么能否更详细显示一些文件属性或信息呢,当然可以,如下所示

  1. [root@getlnx01 u03]# find . -type f -size +800M  -print0 | xargs -0 ls -l

  1. -rw-r----- 1 oracle oinstall 2782846976 Mar  6 11:51 ./flash_recovery_area/backup/backupsets/ora_df873513413_s46809_s1

  1. -rw-r----- 1 oracle oinstall 1878433792 Mar  6 11:53 ./flash_recovery_area/backup/backupsets/ora_df873514789_s46810_s1

  1. -rw-r----- 1 oracle oinstall 1378492416 Mar  6 11:54 ./flash_recovery_area/backup/backupsets/ora_df873515765_s46811_s1

  1. -rw-r----- 1 oracle oinstall 1641381888 Mar  6 11:56 ./flash_recovery_area/backup/backupsets/ora_df873516500_s46812_s1

  1. -rw-r----- 1 oracle oinstall 1564065792 Mar  6 11:58 ./flash_recovery_area/backup/backupsets/ora_df873517396_s46813_s1

  1. -rw-r----- 1 oracle oinstall 1663492096 Mar  6 12:00 ./flash_recovery_area/backup/backupsets/ora_df873518302_s46814_s1

  1. -rw-r----- 1 oracle oinstall 1368244224 Mar  6 12:02 ./flash_recovery_area/backup/backupsets/ora_df873519197_s46815_s1

  1. -rw-r----- 1 oracle oinstall 1629069312 Mar  6 12:04 ./flash_recovery_area/backup/backupsets/ora_df873519953_s46816_s1

  1. -rw-r----- 1 oracle oinstall 1629954048 Mar  6 12:06 ./flash_recovery_area/backup/backupsets/ora_df873520789_s46817_s1

  1. -rw-r----- 1 oracle oinstall 1202192384 Mar  6 12:07 ./flash_recovery_area/backup/backupsets/ora_df873521714_s46818_s1

  1. -rw-r----- 1 oracle oinstall 1189388288 Mar  6 12:10 ./flash_recovery_area/backup/backupsets/ora_df873522876_s46820_s1

  1. -rw-r----- 1 oracle oinstall 1089257472 Mar  6 12:11 ./flash_recovery_area/backup/backupsets/ora_df873523321_s46821_s1

  1. -rw-r----- 1 oracle oinstall 1097687040 Mar  6 12:12 ./flash_recovery_area/backup/backupsets/ora_df873523646_s46822_s1

  1. -rw-r----- 1 oracle oinstall 1051009024 Mar  6 12:13 ./flash_recovery_area/backup/backupsets/ora_df873524162_s46823_s1

  1. -rw-r----- 1 oracle oinstall 4294975488 Apr  3 15:07 ./oradata/epps/gmtinv_d07.dbf

  1. -rw-r----- 1 oracle oinstall 4194312192 Apr  1 22:36 ./oradata/epps/gmtinv_d08.dbf

  1. -rw-r----- 1 oracle oinstall 4294975488 Apr  3 15:54 ./oradata/epps/gmtinv_x01.dbf

  1. -rw-r----- 1 oracle oinstall 4294975488 Apr  3 15:57 ./oradata/epps/gmtinv_x02.dbf

  1. -rw-r----- 1 oracle oinstall 4294975488 Apr  1 22:35 ./oradata/epps/invsubmat_d08.dbf

  1. -rw-r----- 1 oracle oinstall 8589942784 Apr  4 09:55 ./oradata/epps/undotbs01.dbf

  1. -rw-r----- 1 oracle oinstall 8589942784 Apr  4 09:15 ./oradata/epps/undotbs02.dbf

当我们只需要查找超过800M大小文件,并显示查找出来文件的具体大小,可以使用下面命令

  1. [root@getlnx01 u03]# find . -type f -size +800M  -print0 | xargs -0 du -h

  1. 1.3G    ./flash_recovery_area/backup/backupsets/ora_df873519197_s46815_s1

  1. 1.1G    ./flash_recovery_area/backup/backupsets/ora_df873523646_s46822_s1

  1. 1.2G    ./flash_recovery_area/backup/backupsets/ora_df873521714_s46818_s1

  1. 1.2G    ./flash_recovery_area/backup/backupsets/ora_df873522876_s46820_s1

  1. 1.5G    ./flash_recovery_area/backup/backupsets/ora_df873517396_s46813_s1

  1. 1.1G    ./flash_recovery_area/backup/backupsets/ora_df873523321_s46821_s1

  1. 1.3G    ./flash_recovery_area/backup/backupsets/ora_df873515765_s46811_s1

  1. 1.6G    ./flash_recovery_area/backup/backupsets/ora_df873520789_s46817_s1

  1. 1004M   ./flash_recovery_area/backup/backupsets/ora_df873524162_s46823_s1

  1. 1.6G    ./flash_recovery_area/backup/backupsets/ora_df873518302_s46814_s1

  1. 1.6G    ./flash_recovery_area/backup/backupsets/ora_df873519953_s46816_s1

  1. 1.6G    ./flash_recovery_area/backup/backupsets/ora_df873516500_s46812_s1

  1. 2.6G    ./flash_recovery_area/backup/backupsets/ora_df873513413_s46809_s1

  1. 1.8G    ./flash_recovery_area/backup/backupsets/ora_df873514789_s46810_s1

  1. 4.1G    ./oradata/epps/invsubmat_d08.dbf

  1. 4.0G    ./oradata/epps/gmtinv_d08.dbf

  1. 4.1G    ./oradata/epps/gmtinv_x01.dbf

  1. 8.1G    ./oradata/epps/undotbs02.dbf

  1. 4.1G    ./oradata/epps/gmtinv_d07.dbf

  1. 8.1G    ./oradata/epps/undotbs01.dbf

  1. 4.1G    ./oradata/epps/gmtinv_x02.dbf

如果你还需要对查找结果按照文件大小做一个排序,那么可以使用下面命令

  1. [root@getlnx01 u03]# find . -type f -size +800M  -print0 | xargs -0 du -h | sort -nr

  1. 1004M   ./flash_recovery_area/backup/backupsets/ora_df873524162_s46823_s1

  1. 8.1G    ./oradata/epps/undotbs02.dbf

  1. 8.1G    ./oradata/epps/undotbs01.dbf

  1. 4.1G    ./oradata/epps/invsubmat_d08.dbf

  1. 4.1G    ./oradata/epps/gmtinv_x02.dbf

  1. 4.1G    ./oradata/epps/gmtinv_x01.dbf

  1. 4.1G    ./oradata/epps/gmtinv_d07.dbf

  1. 4.0G    ./oradata/epps/gmtinv_d08.dbf

  1. 2.6G    ./flash_recovery_area/backup/backupsets/ora_df873513413_s46809_s1

  1. 1.8G    ./flash_recovery_area/backup/backupsets/ora_df873514789_s46810_s1

  1. 1.6G    ./flash_recovery_area/backup/backupsets/ora_df873520789_s46817_s1

  1. 1.6G    ./flash_recovery_area/backup/backupsets/ora_df873519953_s46816_s1

  1. 1.6G    ./flash_recovery_area/backup/backupsets/ora_df873518302_s46814_s1

  1. 1.6G    ./flash_recovery_area/backup/backupsets/ora_df873516500_s46812_s1

  1. 1.5G    ./flash_recovery_area/backup/backupsets/ora_df873517396_s46813_s1

  1. 1.3G    ./flash_recovery_area/backup/backupsets/ora_df873519197_s46815_s1

  1. 1.3G    ./flash_recovery_area/backup/backupsets/ora_df873515765_s46811_s1

  1. 1.2G    ./flash_recovery_area/backup/backupsets/ora_df873522876_s46820_s1

  1. 1.2G    ./flash_recovery_area/backup/backupsets/ora_df873521714_s46818_s1

  1. 1.1G    ./flash_recovery_area/backup/backupsets/ora_df873523646_s46822_s1

  1. 1.1G    ./flash_recovery_area/backup/backupsets/ora_df873523321_s46821_s1

不过如上截图所示,有时候排列的顺序并不完全是按大小一致,这个是因为du命令的参数h所致,你可以统一使用使用MB来显示,这样就能解决这个问题。到这里,这个在Linux系统查找大文件的命令已经非常完美了,当然如果你还有很多的需求,那么可以在这个命令上做修改、调整.

 

2: 如何查找Linux下的大目录

譬如有时候磁盘空间告警了,而你平时又疏于管理、监控文件的增长,那么我需要快速的了解哪些目录变得比较大,那么此时我们可以借助du命令来帮我们解决这个问题。

  1. [root@getlnx01 u03]# du -h --max-depth=1

  1. 16K     ./lost+found

  1. 33G     ./flash_recovery_area

  1. 37G     ./oradata

  1. 70G     .

如果你想知道flash_recovery_area目录下面有哪些大文件夹,那么可以将参数max-depth=2 ,如果你想对搜索出来的结果进行排序,那么可以借助于sort命令。如下所示

  1. [root@getlnx01 u03]# du -h --max-depth=2 | sort -n

  1. 3.5G    ./flash_recovery_area/EPPS

  1. 16K     ./lost+found

  1. 29G     ./flash_recovery_area/backup

  1. 33G     ./flash_recovery_area

  1. 37G     ./oradata

  1. 37G     ./oradata/epps

  1. 70G     .

  1. [root@getlnx01 u03]# du -hm --max-depth=2 | sort -n

  1. 1       ./lost+found

  1. 3527    ./flash_recovery_area/EPPS

  1. 29544   ./flash_recovery_area/backup

  1. 33070   ./flash_recovery_area

  1. 37705   ./oradata

  1. 37705   ./oradata/epps

  1. 70775   .

[root@getlnx01 u03]# cd /

[root@getlnx01 /]# du -hm --max-depth=2 | sort -n

有时候搜索出来的结果太多了(譬如,我从根目录开始搜索),一直在刷屏,如果我只想查出最大的12个文件夹,怎么办呢?此时就要借助head命令来显示了

  1. [root@getlnx01 /]# du -hm --max-depth=2 | sort -nr | head -12

  1. 407480  .

  1. 167880  ./u04

  1. 158685  ./u02/oradata

  1. 158685  ./u02

  1. 152118  ./u04/oradata

  1. 70775   ./u03

  1. 37705   ./u03/oradata

  1. 33070   ./u03/flash_recovery_area

  1. 5995    ./u01/app

  1. 5995    ./u01

  1. 3551    ./usr

  1. 1558    ./usr/share

  1. [root@getlnx01 /]#

 

参考资料:

http://linuxandfriends.com/how-to-find-large-files-in-linux-using-command-line/

http://www.docin.com/p-563963500.html

Linux如何查找大文件或目录总结的更多相关文章

  1. Linux如何查找大文件或目录总结及在全部目录中查找

    在Windows系统中,我们可以使用TreeSize工具查找一些大文件或文件夹,非常的方便高效,在Linux系统中,如何去搜索一些比较大的文件呢?下面我整理了一下在Linux系统中如何查找大文件或文件 ...

  2. Linux下查找大文件以及目录

    转自:http://www.cnblogs.com/kerrycode/p/4391859.html 在Windows系统中,我们可以使用TreeSize工具查找一些大文件或文件夹,非常的方便高效,在 ...

  3. Linux如何查找大文件或目录总结-1127

    原帖地址:http://www.cnblogs.com/kerrycode/p/4391859.html  谢谢潇湘隐者,谢谢老大 在Linux系统中,如何去搜索一些比较大的文件呢?下面我整理了一下在 ...

  4. Linux下查找大文件,大目录的方法

    查找大文件 //列举出当前目录所有大于800M的文件 find . -type f -size +800M 1 2 第一个方法只用到了一个命令find,它能够帮我们做一些文件查找的操作.它常用的参数有 ...

  5. LINUX下查找大文件及大的文件夹

    原帖地址:https://www.cnblogs.com/iyoume2008/p/6105590.html 今天正好碰到这样的问题,在博客园中看到有以上地址的一篇文章,照着上面的操作解决了问题,但是 ...

  6. linux系统查找大文件脚本

    每次遇到服务器磁盘满,都会很苦恼,但有了下面两种方法就可以轻松找到机器中的大文件了, 第一种:du -sh du -sh 当前目录下个文件或目录的大小: du -sh * 显示前10个占用空间最大的文 ...

  7. Linux如何查找大文件

    https://www.cnblogs.com/kerrycode/p/4391859.html find . -type f -size +800M 如上命令所示,我们仅仅能看到超过800M大小的文 ...

  8. linux下查找某个文件或目录

    以查找samba为例:find / -name samba 查找之后得到的结果集如下:/var/lib/samba/var/spool/samba/var/log/samba/usr/lib64/sa ...

  9. Linux下 查找大文件

    find ./ -size +50M 显示当前路径下,大于50M的文件.(包含子文件夹内的文件)

随机推荐

  1. spring源码分析之spring-core-env

    看一下源码整体: 抓住主要点,Environment.PropertyResolver.PropertySource,其结构如下: 其中, Environment:Interface represen ...

  2. 做图表统计你需要掌握SQL Server 行转列和列转行

    说在前面 做一个数据统计和分析的项目,每天面对着各种数据,经过存储过程从源表计算汇总后需要写入中间结果表以提高数据使用效率,那么此时就需要用到行转列和列转行. 1.列转行 数据经过计算加工后会直接生成 ...

  3. mybatis入门基础(三)----SqlMapConfig.xml全局配置文件解析

    一:SqlMapConfig.xml配置文件的内容和配置顺序如下 properties(属性) settings(全局配置参数) typeAiases(类型别名) typeHandlers(类型处理器 ...

  4. CSS技巧(一):清除浮动

    什么是CSS清除浮动? 在非IE浏览器(如Firefox)下,当容器的高度为auto,且容器的内容中有浮动(float为left或right)的元素,在这种情况下,容器的高度不能自动伸长以适应内容的高 ...

  5. Microsoft Visual Studio 2008 未能正确加载包“Visual Web Developer HTML Source Editor Package” | “Visual Studio HTM Editor Package”

    在安装Microsoft Visual Studio 2008 后,如果Visual Studio 2008的语言版本与系统不一致时,比如:在Windows 7 English System 安装Vi ...

  6. 基于C#的MongoDB数据库开发应用(4)--Redis的安装及使用

    在前面介绍了三篇关于MongoDB数据库的开发使用文章,严格来讲这个不能归类于MongoDB数据库开发,不过Redis又有着和MongoDB数据库非常密切的关系,它们两者很接近,Redis主要是内存中 ...

  7. HighchartsNET快速图表控件-开源

    前言: HighchartsNET快速图表控件,基于Highcharts的asp.net web控件.只需几行代码你就能快速生成一个图表. 从此不再担心图表复杂.简单几行代码就可以搞定,节省大量工作时 ...

  8. xhtmlConformance与xhtml脚本呈现

    此配置节只有一个属性——mode,该特性为 ASP.NET 应用程序指定 XHTML 呈现模式.它包含三个值 要让此配置生效,需要把<pages>配置节中的controlRendering ...

  9. php xml 文件读取 XMLReader

    php xml 文件读取 <?php /** $xmlString = '<xml> <persons count="10"> <person ...

  10. java Byte[] to String(hex)

    1. 字节数组转换成16进制字符展示 2.代码 package com.goodfan; public class ByteArrayToString { private static char[] ...