zoukankan      html  css  js  c++  java
  • shell学习(9)- du和df区别及详解

    清明小长假来加班,总得干点啥吧,今天就说说du 和df的区别。

    1.区别

    du,disk usage,是通过搜索文件来计算每个文件的大小然后累加,du能看到的文件只是一些当前存在的,没有删除的。他计算的是当前他认为的所有文件大小的累加。

    df,disk free,通过文件系统来快速获取空间大小的信息,当我们删除一个文件的时候,这个文件不是马上就在文件系统中消失了,而是暂时消失了,当所有程序都不用时,才会根据操作系统的规则释放掉已经删除的文件,df记录的是通过文件系统获取到的文件的大小,他比du强的地方就是能看到已经删除的文件。

    当文件系统也确定删除了该文件后,这时候du与df就一致了。

    2.du详解

    2.1命令格式

    du [选项][文件]

    2.2命令功能

    显示每个文件和目录的磁盘使用空间。

    2.3命令参数

    -a或-all  显示目录中个别文件的大小。   
    -b或-bytes  显示目录或文件大小时,以byte为单位。   
    -c或--total  除了显示个别目录或文件的大小外,同时也显示所有目录或文件的总和。 
    -k或--kilobytes  以KB(1024bytes)为单位输出。
    -m或--megabytes  以MB为单位输出。   
    -s或--summarize  仅显示总计,只列出最后加总的值。
    -h或--human-readable  以K,M,G为单位,提高信息的可读性。
    -x或--one-file-xystem  以一开始处理时的文件系统为准,若遇上其它不同的文件系统目录则略过。 
    -L<符号链接>或--dereference<符号链接> 显示选项中所指定符号链接的源文件大小。   
    -S或--separate-dirs   显示个别目录的大小时,并不含其子目录的大小。 
    -X<文件>或--exclude-from=<文件>  在<文件>指定目录或文件。   
    --exclude=<目录或文件>         略过指定的目录或文件。    
    -D或--dereference-args   显示指定符号链接的源文件大小。   
    -H或--si  与-h参数相同,但是K,M,G是以1000为换算单位。   
    -l或--count-links   重复计算硬件链接的文件。 

    2.4使用实例

    1.du,显示目录或者文件所占空间,只显示当前目录下面的子目录的目录大小和当前目录的总的大小,最下面的1288为当前目录的总大小

    [root@localhost test]# du
    608     ./test6
    308     ./test4
    4       ./scf/lib
    4       ./scf/service/deploy/product
    4       ./scf/service/deploy/info
    12      ./scf/service/deploy
    16      ./scf/service
    4       ./scf/doc
    4       ./scf/bin
    32      ./scf
    8       ./test3
    1288    .

    2.du,查看指定目录的所占空间

    [root@localhost ~]$ du hadoop
    20    hadoop/log/hive/kumufengchun
    24    hadoop/log/hive
    28    hadoop/log
    32    hadoop

    3.du,显示指定文件所占空间

    [root@localhost ~]$ du test.sh
    4    test.sh

    4.du,显示多个文件所占空间

    [root@localhost ~]$ du test.sh black.txt
    4    test.sh
    4    black.txt

    5.du -s,只显示总和的大小

    [root@localhost ~]$ du -s hadoop
    32    hadoop
    [root@localhost ~]# du -s /home/*
    364    /home/kumufengchun
    24    /home/qingyangwanxi
    20    /home/dongxuewanqing
    16    /home/qingwufeiyang

    6.du -h,方便阅读的格式显示

    [root@localhost ~]# du -h hadoop
    20K    hadoop/log/hive/kumufengchun
    24K    hadoop/log/hive
    28K    hadoop/log
    32K    hadoop

    7.du -a,文件和目录都显示

    [root@localhost ~]# du -ah hadoop
    16K    hadoop/log/hive/kumufengchun/hive.log
    20K    hadoop/log/hive/kumufengchun
    24K    hadoop/log/hive
    28K    hadoop/log
    32K    hadoop

    8.du -c,显示几个文件或目录各自占用磁盘空间的大小,还统计它们的总和

    [root@localhost test]# du -c log30.tar.gz log31.tar.gz 
    4       log30.tar.gz
    4       log31.tar.gz
    8       总计

    9.按照空间大小排序

    [root@localhost test]# du|sort -nr|more
    1288    .
    608     ./test6
    308     ./test4
    32      ./scf
    16      ./scf/service
    12      ./scf/service/deploy
    8       ./test3
    4       ./scf/service/deploy/product
    4       ./scf/service/deploy/info
    4       ./scf/lib
    4       ./scf/doc
    4       ./scf/bin

    10.输出当前目录下各个子目录所使用的空间

    [root@localhost test]# du -h  --max-depth=1
    608K    ./test6
    308K    ./test4
    32K     ./scf
    8.0K    ./test3
    1.3M    .

    11.选项--exclude和--exclude-from可以让du在磁盘使用统计中排除部分文件

    [root@localhost test]# du --exclude "*.txt" -a shell/
    4    shell/ifs.sh
    4    shell/TEST.TXT
    4    shell/disklog.sh
    4    shell/file.sh
    4    shell/timing.log
    4    shell/exit.sh
    4    shell/1.sh

    3.df详解

    linux中df命令是用来检查linux服务器的文件系统的磁盘占用空间情况。可以利用该命令来获取硬盘被占用了多少空间,母亲还剩下多少空间等信息

    3.1命令格式

    df [选项] [文件]

    3.2命令功能

    显示指定磁盘文件的可用空间。如果没有文件名被指定,则所有当前被挂载的文件系统的可用空间将被显示。默认情况下,磁盘空间将以 1KB 为单位进行显示,除非环境变量 POSIXLY_CORRECT 被指定,那样将以512字节为单位进行显示

    3.3命令参数

    必要参数:
    -a 全部文件系统列表
    -h 方便阅读方式显示
    -H 等于“-h”,但是计算式,1K=1000,而不是1K=1024
    -i 显示inode信息
    -k 区块为1024字节
    -l 只显示本地文件系统
    -m 区块为1048576字节
    --no-sync 忽略 sync 命令
    -P 输出格式为POSIX
    --sync 在取得磁盘信息前,先执行sync命令
    -T 文件系统类型
    选择参数:
    --block-size=<区块大小> 指定区块大小
    -t<文件系统类型> 只显示选定文件系统的磁盘信息
    -x<文件系统类型> 不显示选定文件系统的磁盘信息
    --help 显示帮助信息
    --version 显示版本信息

    3.4使用实例

    1.df显示磁盘使用情况

    [root@CT1190 log]# df
    文件系统               1K-块        已用     可用 已用% 挂载点
    /dev/sda7             19840892    890896  17925856   5% /
    /dev/sda9            203727156 112797500  80413912  59% /opt
    /dev/sda8              4956284    570080   4130372  13% /var
    /dev/sda6             19840892   1977568  16839184  11% /usr
    /dev/sda3               988116     23880    913232   3% /boot
    tmpfs                 16473212         0  16473212   0% /dev/shm

    说明:

    linux中df命令的输出清单的第1列是代表文件系统对应的设备文件的路径名(一般是硬盘上的分区);第2列给出分区包含的数据块(1024字节)的数目;第3,4列分别表示已用的和可用的数据块数目。用户也许会感到奇怪的是,第3,4列块数之和不等于第2列中的块数。这是因为缺省的每个分区都留了少量空间供系统管理员使用。即使遇到普通用户空间已满的情况,管理员仍能登录和留有解决问题所需的工作空间。清单中Use% 列表示普通用户空间使用的百分比,即使这一数字达到100%,分区仍然留有系统管理员使用的空间。最后,Mounted on列表示文件系统的挂载点

    2.df -i,以inode模式来显示磁盘使用情况

    [root@CT1190 log]# df -i
    文件系统               Inode (I)已用 (I)可用 (I)已用% 挂载点
    /dev/sda7            5124480    5560 5118920    1% /
    /dev/sda9            52592640   50519 52542121    1% /opt
    /dev/sda8            1280000    8799 1271201    1% /var
    /dev/sda6            5124480   80163 5044317    2% /usr
    /dev/sda3             255232      34  255198    1% /boot
    tmpfs                4118303       1 4118302    1% /dev/shm

    3.df -T,列出文件系统的类型

    [root@CT1190 log]# df -T
    文件系统      类型     1K-块        已用     可用 已用% 挂载点
    /dev/sda7     ext3    19840892    890896  17925856   5% /
    /dev/sda9     ext3   203727156  93175692 100035720  49% /opt
    /dev/sda8     ext3     4956284    570104   4130348  13% /var
    /dev/sda6     ext3    19840892   1977568  16839184  11% /usr
    /dev/sda3     ext3      988116     23880    913232   3% /boot
    tmpfs        tmpfs    16473212         0  16473212   0% /dev/shm

    4.显示指定类型磁盘

    [root@CT1190 log]# df -t ext3
    文件系统               1K-块        已用     可用 已用% 挂载点
    /dev/sda7             19840892    890896  17925856   5% /
    /dev/sda9            203727156  93089700 100121712  49% /opt
    /dev/sda8              4956284    570104   4130348  13% /var
    /dev/sda6             19840892   1977568  16839184  11% /usr
    /dev/sda3               988116     23880    913232   3% /boot

    5.列出各文件系统的i节点使用情况

    [root@CT1190 log]# df -ia
    文件系统               Inode (I)已用 (I)可用 (I)已用% 挂载点
    /dev/sda7            5124480    5560 5118920    1% 
    /proc                       0       0       0    -  /proc
    sysfs                      0       0       0    -  /sys
    devpts                     0       0       0    -  /dev/pts
    /dev/sda9            52592640   50519 52542121    1% /opt
    /dev/sda8            1280000    8799 1271201    1% /var
    /dev/sda6            5124480   80163 5044317    2% /usr
    /dev/sda3             255232      34  255198    1% /boot
    tmpfs                4118303       1 4118302    1% /dev/shm
    none                       0       0       0    -  /proc/sys/fs/binfmt_misc

    6.以更易读的方式显示目前磁盘空间和使用情况

    [root@CT1190 log]# df -h
    文件系统              容量  已用 可用 已用% 挂载点
    /dev/sda7              19G  871M   18G   5% /
    /dev/sda9             195G   89G   96G  49% /opt
    /dev/sda8             4.8G  557M  4.0G  13% /var
    /dev/sda6              19G  1.9G   17G  11% /usr
    /dev/sda3             965M   24M  892M   3% /boot
    tmpfs                  16G     0   16G   0% /dev/shm
    [root@CT1190 log]# df -H
    文件系统               容量   已用  可用 已用% 挂载点
    /dev/sda7               21G   913M    19G   5% /
    /dev/sda9              209G    96G   103G  49% /opt
    /dev/sda8              5.1G   584M   4.3G  13% /var
    /dev/sda6               21G   2.1G    18G  11% /usr
    /ev/sda3              1.1G    25M   936M   3% /boot
    tmpfs                   17G      0    17G   0% /dev/shm
    [root@CT1190 log]# df -lh
    文件系统              容量  已用 可用 已用% 挂载点
    /dev/sda7              19G  871M   18G   5% /
    /dev/sda9             195G   89G   96G  49% /opt
    /dev/sda8             4.8G  557M  4.0G  13% /var
    /dev/sda6              19G  1.9G   17G  11% /usr
    /dev/sda3             965M   24M  892M   3% /boot
    tmpfs                  16G     0   16G   0% /dev/shm
    [root@CT1190 log]# df -k
    文件系统               1K-块        已用     可用 已用% 挂载点
    /dev/sda7             19840892    890896  17925856   5% /
    /dev/sda9            203727156  93292572  99918840  49% /opt
    /dev/sda8              4956284    570188   4130264  13% /var
    /dev/sda6             19840892   1977568  16839184  11% /usr
    /dev/sda3               988116     23880    913232   3% /boot
    tmpfs                 16473212         0  16473212   0% /dev/shm

    说明:

    -h更具目前磁盘空间和使用情况 以更易读的方式显示

    -H根上面的-h参数相同,不过在根式化的时候,采用1000而不是1024进行容量转换

    -k以单位显示磁盘的使用情况

    -l显示本地的分区的磁盘空间使用率,如果服务器nfs了远程服务器的磁盘,那么在df上加上-l后系统显示的是过滤nsf驱动器后的结果

    -i显示inode的使用情况。linux采用了类似指针的方式管理磁盘空间影射.这也是一个比较关键应用

    原文连接 https://blog.csdn.net/wisgood/article/details/17316663

  • 相关阅读:
    Autofac +webapi 配置
    net 记录controller Action耗时
    C# ASP.NET Core使用HttpClient的同步和异步请求
    C#实体对象序列化成Json,格式化,并让字段的首字母小写
    Razor 将C#对象转换成Javascript对象, json还原被转码的字符 &quot·· HTML转义符
    js 递归树结构数据查找父级
    api下载文件
    Ubuntu django+nginx 搭建python web服务器文件日志
    python scrapy cookies 处理
    ubuntu 环境下pycharm的 安装与激活教程 以及错误解决方法
  • 原文地址:https://www.cnblogs.com/kumufengchun/p/10661152.html
Copyright © 2011-2022 走看看