df -h和du -h 占用空间为什么差这么多?

当磁盘大小超过标准时会有报警提示,这时如果掌握df和du命令是非常明智的选择。

   df可以查看一级文件夹大小、使用比例、档案系统及其挂入点,但对文件却无能为力。
   du可以查看文件及文件夹的大小。

   两者配合使用,非常有效。比如用df查看哪个一级目录过大,然后用df查看文件夹或文件的大小,如此便可迅速确定症结。

    下面分别简要介绍

    df命令可以显示目前所有文件系统的可用空间及使用情形,请看下列这个例子:

 

以下是代码片段:

[yayug@yayu ~]$ df -h
Filesystem           Size  Used Avail Use% Mounted on
/dev/sda1            3.9G  300M 3.4G   8% /
/dev/sda7            100G  188M  95G   1% /data0
/dev/sdb1            133G  80G   47G  64% /data1
/dev/sda6            7.8G  218M 7.2G   3% /var
/dev/sda5            7.8G  166M 7.2G   3% /tmp
/dev/sda3            9.7G  2.5G 6.8G  27% /usr
tmpfs                2.0G    0  2.0G   0% /dev/shm

 

    参数 -h 表示使用「Human-readable」的输出,也就是在档案系统大小使用 GB、MB 等易读的格式。

   上面的命令输出的第一个字段(Filesystem)及最后一个字段(Mounted on)分别是档案系统及其挂入点。我们可以看到 /dev/sda1 这个分割区被挂在根目录下。

    接下来的四个字段 Size、Used、Avail、及 Use% 分别是该分割区的容量、已使用的大小、剩下的大小、及使用的百分比。 FreeBSD下,当硬盘容量已满时,您可能会看到已使用的百分比超过 100%,因为 FreeBSD 会留一些空间给 root,让 root 在档案系统满时,还是可以写东西到该档案系统中,以进行管理。

    du:查询文件或文件夹的磁盘使用空间

   如果当前目录下文件和文件夹很多,使用不带参数du的命令,可以循环列出所有文件和文件夹所使用的空间。这对查看究竟是那个地方过大是不利的,所以得指定深入目录的层数,参数:--max-depth=,这是个极为有用的参数!如下,注意使用“*”,可以得到文件的使用空间大小.

 

 du 统计文件大小相加 
   df  统计数据块使用情况

   如果有一个进程在打开一个大文件的时候,这个大文件直接被rm 或者mv掉,则du会更新统计数值,df不会更新统计数值,还是认为空间没有释放。直到这个打开大文件的进程被Kill掉。

    如此一来在定期删除 /var/spool/clientmqueue下面的文件时,如果没有杀掉其进程,那么空间一直没有释放。

   使用下面的命令杀掉进程之后,系统恢复。
    fuser -u /var/spool/clientmqueue

客户那里一台主机出了问题,df -h比du -h大了15G,邪门的很,google了一下。发现差异有两种。
1:meta data导致不一致,但是相差应该不会很大。顶天百M左右,就是i-node那些元数据占用掉的。
2:root删除应用程序正在调用的打开的文件,通常是清理日志的时候,直接删除,而这时句柄文件仍然存在。在df -h仍然显示空间未被释放。
最终确认是客户误删除了太大的日志文件。导致问题出现。重启应用程序即可。


检查方法:lsof /softusedir | grep deleted


具体操作步骤如下:


KOOK-SLES9:~ # df -h /soft
Filesystem            Size  Used Avail Use% Mounted on
/dev/mapper/vgroot-soft
                      20G  17G  2.4G  88% /soft
KOOK-SLES9:~ # du -sh /soft
2.0G    /soft
KOOK-SLES9:~ # fuser -uv /soft

                    USER        PID ACCESS COMMAND
/soft                root    kernel mount  /soft

KOOK-SLES9:~ # lsof /soft | grep delete
httpd    675  nobody    2w  REG  253,7  1243716399 2410028 /soft/IBMIHS/logs/error_log (deleted)
httpd    675  nobody    6w  REG  253,7  1243716399 2410028 /soft/IBMIHS/logs/error_log (deleted)
httpd    675  nobody    7w  REG  253,7 14072560792 2410026 /soft/IBMIHS/logs/access_log (deleted)
httpd    720  nobody    2w  REG  253,7  1243716399 2410028 /soft/IBMIHS/logs/error_log (deleted)
httpd    720  nobody    6w  REG  253,7  1243716399 2410028 /soft/IBMIHS/logs/error_log (deleted)
httpd    720  nobody    7w  REG  253,7 14072560792 2410026 /soft/IBMIHS/logs/access_log (deleted)
httpd    1590  nobody    2w  REG  253,7  1243716399 2410028 /soft/IBMIHS/logs/error_log (deleted)
httpd    1590  nobody    6w  REG  253,7  1243716399 2410028 /soft/IBMIHS/logs/error_log (deleted)
httpd    1590  nobody    7w  REG  253,7 14072560792 2410026 /soft/IBMIHS/logs/access_log (deleted)
httpd    4826    root    2w  REG  253,7  1243716399 2410028 /soft/IBMIHS/logs/error_log (deleted)
httpd    4826    root    6w  REG  253,7  1243716399 2410028 /soft/IBMIHS/logs/error_log (deleted)
httpd    4826    root    7w  REG  253,7 14072560792 2410026 /soft/IBMIHS/logs/access_log (deleted)
httpd    4827  nobody    2w  REG  253,7  1243716399 2410028 /soft/IBMIHS/logs/error_log (deleted)
httpd    4827  nobody    6w  REG  253,7  1243716399 2410028 /soft/IBMIHS/logs/error_log (deleted)
httpd    4827  nobody    7w  REG  253,7 14072560792 2410026 /soft/IBMIHS/logs/access_log (deleted)
httpd  17505  nobody    2w  REG  253,7  1243716399 2410028 /soft/IBMIHS/logs/error_log (deleted)
httpd  17505  nobody    6w  REG  253,7  1243716399 2410028 /soft/IBMIHS/logs/error_log (deleted)
httpd  17505  nobody    7w  REG  253,7 14072560792 2410026 /soft/IBMIHS/logs/access_log (deleted)
KOOK-SLES9:~ # lsof /soft | head -2
COMMAND  PID    USER  FD   TYPE DEVICE        SIZE    NODE NAME
httpd    675  nobody  txt    REG  253,7      473649 2410022 /soft/IBMIHS/bin/httpd
KOOK-SLES9:~ # ps aux | grep 675
nobody    675  0.0  0.1  73340 14436 ?        Sl  11:12   0:06 /soft/IBMIHS/bin/httpd -d /soft/IBMIHS -k start
root      6594  0.0  0.0  1716   656 pts/2    S+  13:10   0:00 grep 675
KOOK-SLES9:~ # ps aux | grep IBMIHS | grep httpd
root      4826  0.0  0.1  14036 10424 ?        Ss    2008  0:02 /soft/IBMIHS/bin/httpd -d /soft/IBMIHS -k start
nobody    4827  0.0  0.0  3660  2064 ?        S    2008   0:00 /soft/IBMIHS/bin/httpd -d /soft/IBMIHS -k start
nobody  17505  0.0  0.1  71968 13208 ?        Sl  Apr08   0:00 /soft/IBMIHS/bin/httpd -d /soft/IBMIHS -k start
nobody    675  0.0  0.1  73340 14436 ?        Sl  11:12   0:06 /soft/IBMIHS/bin/httpd -d /soft/IBMIHS -k start
nobody    720  0.0  0.1  73120 13952 ?        Sl  11:12   0:06 /soft/IBMIHS/bin/httpd -d /soft/IBMIHS -k start
nobody    1590  0.0  0.1  72056 13912 ?        Sl  11:26   0:05 /soft/IBMIHS/bin/httpd -d /soft/IBMIHS -k start
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值