zoukankan      html  css  js  c++  java
  • LINUX下查找大文件及大的文件夹

    原帖地址:https://www.cnblogs.com/iyoume2008/p/6105590.html

    今天正好碰到这样的问题,在博客园中看到有以上地址的一篇文章,照着上面的操作解决了问题,但是排版上看着不是特别舒服,自己也想记录下来,就全文COPY了,只是改了下版式。望作者谅解

    如何查找大文件

    其实很多时候,你需要了解 /u01/app/oracle/oradata/prod/ 下有哪些大的数据文件,比如文件大小超过100M或1G(阀值视具体情况而定)。那么如何把这些大文件搜索出来呢?

    1.1搜索指定目录下超过指定大小的文件

    例如我要搜索 /u01/app/oracle/oradata/prod/ 下,超过500M大小的文件

    [oracle@Oracle11g ~]$ find /u01/app/oracle/oradata/prod/  -type f -size +500M
    
    /u01/app/oracle/oradata/prod/sysaux01.dbf
    
    /u01/app/oracle/oradata/prod/system01.dbf

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

    1.2搜索指定目录下超过指定大小的文件(显示文件用户、属组)

    [oracle@Oracle11g ~]$ find /u01/app/oracle/oradata/prod/  -type f -size +500M  -print0 | xargs -0 ls –l
    
    -rw-r----- 1 oracle oinstall 545267712 11-19 23:20 /u01/app/oracle/oradata/prod/sysaux01.dbf
    
    -rw-r----- 1 oracle oinstall 744497152 11-19 23:20 /u01/app/oracle/oradata/prod/system01.dbf

    1.3搜索指定目录下超过指定大小的文件(显示文件详细size)

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

    [oracle@Oracle11g ~]$ find /u01/app/oracle/oradata/prod/ -type f -size +500M  -print0 | xargs -0 du –h
    
    521M    /u01/app/oracle/oradata/prod/sysaux01.dbf
    
    711M    /u01/app/oracle/oradata/prod/system01.dbf

    1.4搜索指定目录下超过指定大小的文件(按大小排序,结果有出入)

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

    [oracle@Oracle11g ~]$ find /u01/app/oracle/oradata/prod/  -type f -size +500M  -print0 | xargs -0 du -h | sort -nr
    
    711M    /u01/app/oracle/oradata/prod/system01.dbf
    
    521M    /u01/app/oracle/oradata/prod/sysaux01.dbf

    1.5搜索指定目录下超过指定大小的文件(按大小排序,严格的)

    不过如上截图所示,有时候排列的顺序并不完全是按大小一致,这个是因为du命令的参数h所致,你可以统一使用使用MB来显示,这样就能解决这个问题

    [oracle@Oracle11g ~]$ find /u01/app/oracle/oradata/prod/ -type f -size +500M -print0 | xargs -0 du -hm | sort –n
    
    521     /u01/app/oracle/oradata/prod/sysaux01.dbf
    
    711     /u01/app/oracle/oradata/prod/system01.dbf

    1.6 搜索指定目录下超过指定大小的文件(详细显示文件的属主、属组、文件大小(M为单位))

    [oracle@Oracle11g ~]$ find /u01/app/oracle/oradata/prod/  -type f -size +500M  -print0 | xargs -0 ls -lh  | sort -nr
    
    rw-r----- 1 oracle oinstall 711M 11-20 09:06 /u01/app/oracle/oradata/prod/system01.dbf
    -rw-r----- 1 oracle oinstall 521M 11-20 09:06 /u01/app/oracle/oradata/prod/sysaux01.dbf

    如何查找Linux下的大目录

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

    2.1查找指定目录下的大目录

    [oracle@Oracle11g ~]$ du -h /u01  --max-depth=1
    
    5.7G    /u01/app
    
    16K     /u01/lost+found
    
    5.7G    /u01
    
    [oracle@Oracle11g ~]$ du -h /u01  --max-depth=2
    
    2.6M    /u01/app/oraInventory
    
    5.7G    /u01/app/oracle
    
    5.7G    /u01/app
    
    16K     /u01/lost+found
    
    5.7G    /u01
    
    [oracle@Oracle11g ~]$ du -h /u01  --max-depth=3
    
    16K     /u01/app/oraInventory/ContentsXML
    
    8.0K    /u01/app/oraInventory/oui
    
    2.6M    /u01/app/oraInventory/logs
    
    2.6M    /u01/app/oraInventory
    
    1.7G    /u01/app/oracle/oradata
    
    4.0K    /u01/app/oracle/checkpoints
    
    4.0G    /u01/app/oracle/product
    
    716K    /u01/app/oracle/admin
    
    232K    /u01/app/oracle/cfgtoollogs
    
    6.8M    /u01/app/oracle/diag
    
    5.7G    /u01/app/oracle
    
    5.7G    /u01/app
    
    16K     /u01/lost+found
    
    5.7G    /u01

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

    [oracle@Oracle11g ~]$ du -h /u01  --max-depth=2 |sort -n
    
    2.6M    /u01/app/oraInventory
    
    5.7G    /u01
    
    5.7G    /u01/app
    
    5.7G    /u01/app/oracle
    
    16K     /u01/lost+found
    
    [oracle@Oracle11g ~]$ du -h /u01  --max-depth=3 |sort -n
    
    1.7G    /u01/app/oracle/oradata
    
    2.6M    /u01/app/oraInventory
    
    2.6M    /u01/app/oraInventory/logs
    
    4.0G    /u01/app/oracle/product
    
    4.0K    /u01/app/oracle/checkpoints
    
    5.7G    /u01
    
    5.7G    /u01/app
    
    5.7G    /u01/app/oracle
    
    6.8M    /u01/app/oracle/diag
    
    8.0K    /u01/app/oraInventory/oui
    
    16K     /u01/app/oraInventory/ContentsXML
    
    16K     /u01/lost+found
    
    232K    /u01/app/oracle/cfgtoollogs
    
    716K    /u01/app/oracle/admin

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

    [oracle@Oracle11g ~]$ du -hm /u01/app/oracle/ --max-depth=2 | sort -nr | head -5
    
    5741    /u01/app/oracle/
    
    4057    /u01/app/oracle/product/11.2.0
    
    4057    /u01/app/oracle/product
    
    1677    /u01/app/oracle/oradata/prod
    
    1677    /u01/app/oracle/oradata

    3.自己整理的(实用的)

    3.1 查找系统中的大目录(从大到小排序,取前5个)

    [root@Oracle11g ~]# du -hm / --max-depth=1 | sort -nr | head -5
    
    9456    /
    5744    /u01
    2964    /usr
    260     /dev
    234     /lib

    3.2 查找上面目录(/u01)中的大文件

    [root@Oracle11g ~]#  find /u01/app/oracle/  -type f -size +500M  -print0 | xargs -0 ls -lh  | sort -nr
    
    -rw-r----- 1 oracle oinstall 711M 11-20 09:41 /u01/app/oracle/oradata/prod/system01.dbf
    -rw-r----- 1 oracle oinstall 521M 11-20 09:36 /u01/app/oracle/oradata/prod/sysaux01.dbf 
  • 相关阅读:
    php 导出csv文件
    dns 服务器配置
    ettercap ARP dns 欺骗
    for循环内 执行$ajax(){}
    js 如何生成二维数组
    jquery读取csv文件并用json格式输出
    echo 换行
    cmd命令运行php,php通过cmd运行文件
    Git 常用命令整理
    图像裁剪插件
  • 原文地址:https://www.cnblogs.com/gspsuccess/p/9262140.html
Copyright © 2011-2022 走看看