linux du命令的疑惑
起因是测试rsync传输数据。传输完成后,想看一下传输的文件是不是完整,所以检测了下源目录和目标目录的大小,竟然出现了巨大的差距:
[root@w anaconda3]$ du -sh ./
.9G ./
以及
[root@test anaconda3]# du -sh ./
4.7G ./
同样一个anaconda3目录,在新机器占用的磁盘大小竟然比源机器上多了将近2个G!!比原来的目录小还可以理解为传输问题,比原来的目录大就很奇怪了。
在去看看文件的数量是不是一致:
[root@w anaconda3]$ find ./ | wc -l
[root@test anaconda3]$ find ./ | wc -l
数量是一样的,更奇怪了,继续查看子目录大小:
[root@w anaconda3]$ ls| xargs -n du -sh
139M bin
2.0M compiler_compat
4.1M conda-meta
544K doc
envs
40K etc
56M include
.9G lib
680K libexec
.0K LICENSE.txt
52K man
2.6M mkspecs
320K phrasebooks
.6G pkgs
4.2M plugins
6.2M qml
65M share
4.7M ssl
11M translations
484K var
.0K x86_64-conda_cos6-linux-gn
[root@test anaconda3]# ls| xargs -n du -sh
139M bin
2.0M compiler_compat
4.1M conda-meta
540K doc
envs
40K etc
56M include
.8G lib
676K libexec
.0K LICENSE.txt
48K man
2.5M mkspecs
320K phrasebooks
.6G pkgs
4.2M plugins
6.2M qml
65M share
4.7M ssl
11M translations
484K var
.0K x86_64-conda_cos6-linux-gnu
对比一下,发现差距并不大啊(⊙o⊙)…,这就有点奇怪了,从结果来看新机器上"du -sh ./"的结果应该是对的,应该是老机器上执行"du -sh ./"的结果有点问题。
所以关注的重点转移到老机器上的“du”命令。
根据google到的信息,主要集中在下面几点上:
. du和ls的对比:du默认统计的是文件所占用的块的大小,操作系统分配磁盘空间是以块为单位,即使实际使用的空间不足一个块,别的文件也不能使用这个块空间。ls命令统计的是文件使用的实际空间。一般文件du命令的结果会比ls大一些,而特殊文件如“稀疏文件”,du的结果可能会小一些,这应该是和“稀疏文件”的存储方式有关。
2. du命令也可以统计实际空间,使用“-b”选项
3. du -sh ./* 和 du -sh ./ 结果可能不同,因为./*不会匹配隐藏文件,也就是“.name”以“.”开头的文件。同理du -sh * 和 du -sh 结果也可能不同
4. du和df的对比:如果某个文件被删除了,但依然有进程打开了它,那么df会计入这个文件,但du不会;稀疏文件也可能导致不同。
这几点都没有解释在老机器上运行du命令显示的奇怪结果,所以继续试试其他命令,包括列出每个文件的大小并加总等:
find ./ | xargs du -b | awk 'BEGIN {sum=0} ; {sum+=$1} END {print sum}'
find ./ -type l -o -type f| xargs du -b | awk 'BEGIN {sum=0} ; {sum+=$1} END {print sum}'
ls -l -R | awk 'BEGIN {sum=0} ; {sum+=$5} END {print sum}'
ls -a | xargs du -b | awk 'BEGIN {sum=0} ; {sum+=$1} END {print sum}'
find ./ -not -type d | xargs du | awk 'BEGIN {sum=0} ; {sum+=$1} END {print sum}'
find ./ -not -type d | xargs ls -l | awk 'BEGIN {sum=0} ; {sum+=$5} END {print sum}'
ls | xargs -n du -sb | awk 'BEGIN {sum=0} ; {sum+=$1} END {print sum}'
ll | grep -v ^d | awk 'BEGIN {sum=0} ; {sum+=$5} END {print sum}'
du -abhc ./ | wc -l
p.s. xargs命令默认是把所有参数一起放在命令行上传给程序,所以ls -a | xargs du -b的结果可能是du -b a.txt b.txt ...,而xargs -n 1di -b的结果是du -b a.txt;du -b b.txt等。
上面的命令仍然解释不了原因。
google上也提到过rsync传输后目录大小不一致的可能原因:
. 硬链接。rsync默认会把2个硬链接文件复制成两个文件,磁盘占用空间就多了一个文件的大小。
. 稀疏文件。rsync默认不会写这一类文件
检查了一番之后,似乎只有软连接,没什么硬链接。
最后没有办法,试了试VNC链接图形界面:

神奇的发现:这里的文件大小。。。也是不对的。(⊙o⊙)…
这。。。不知道怎么下手了,打算就此打住,姑且当做是一个bug吧。
另外,google上也提到了一个验证文件完整性的方法:通过checksum 校验和验证。
[root@w anaconda3]$ find . -type f \( -exec sha1sum "{}" \; \) | sort -k2, | sha1sum
ab15e4e01e363e69bf80d1d0aecdf101452f85d6 -
[root@test anaconda3]$ find . -type f \( -exec sha1sum "{}" \; \) | sort -k2,2 | sha1sum
ab15e4e01e363e69bf80d1d0aecdf101452f85d6 -
结果一致,但时间上会慢不少。
linux du命令的疑惑的更多相关文章
- LInux : du命令
Linux du命令也是查看使用空间的,但是与df命令不同的是Linux du命令是对文件和目录磁盘使用的空间的查看,还是和df命令有一些区别的. 1.命令格式: du [选项][文件] 2.命令功能 ...
- (转)linux du命令
转自 http://www.cnblogs.com/peida/archive/2012/12/10/2810755.html Linux du命令也是查看使用空间的,但是与df命令不同的是Linux ...
- linux du命令: 显示文件、目录大小
介绍:du命令用于显示指定文件(夹)在磁盘中所占的空间信息.假如指定的文件参数实际上是一个目录,就要计算该目录下的所有文件.假如 没有提供文件参数,执行du命令,显示当前目录内的文件占用空间信息. 语 ...
- python计算文件夹大小(linux du命令 简化版)
C盘又满了,怎么办?用了一些垃圾清理软件(或者bat脚本),但是还是不理想,那么具体哪些文件夹下面有巨大的文件呢?windows并不能通过详细信息看到每个文件夹的大小(PS:这里所谓的文件夹的大小是指 ...
- Linux du命令和df命令区别
du 命令 1.命令格式: du [选项][文件] 2.命令功能: 显示每个文件和目录的磁盘使用空间. 3.命令参数: -a或-all 显示目录中个别文件的大小. -b或-bytes 显示目录或文件大 ...
- 浅谈Linux du命令
**du(disk usage),顾名思义,查看目录/文件占用空间大小** 1.查看当前目录下的所有目录以及子目录的大小 du -h du -ah #-h:用K.M.G的人性化形式显示#-a:显示目 ...
- Linux du命令详解
1.命令:du 2.命令功能:显示每个文件和目录的磁盘使用空间. 3.命令参数 -a或-all #显示目录中个别文件的大小. -b或-bytes #显示目录或文件大小时,以byte为单位. -c或-- ...
- linux sed命令使用疑惑总结
s 替换命令 [zhuhc@test111 ~]$ sed 's/ma/mass' test.txt , : unterminated `s' command 原因:替换命令s末尾的斜杠丢失了.正确命 ...
- 每天一个linux命令(34):du 命令
Linux du命令也是查看使用空间的,但是与df命令不同的是Linux du命令是对文件和目录磁盘使用的空间的查看,还是和df命令有一些区别的. 1.命令格式: du [选项][文件] 2.命令功能 ...
随机推荐
- django-vue之信息过滤(过滤课程)
一 vue前端代码 实现的内容,通过对课程的分类,在每个不同的课程分类下显示相应的内容 <template> <div class="course"> & ...
- 网络编程(基于udp协议的套接字/socketserver模块/进程简介)
一.基于UDP协议的套接字 TCP是建立可靠连接,并且通信双方都可以以流的形式发送数据.相对TCP,UDP则是面向无连接的协议. 使用UDP协议时,不需要建立连接,只需要知道对方的IP地址和端口号,就 ...
- thinkphp curd的事务回滚 一看就会
版权声明:本文为博主原创文章,未经博主同意不得转载. https://blog.csdn.net/qq1355541448/article/details/32314403 /** ...
- IntBuffer类的基本用法
package com.ietree.basicskill.socket.basic.nio; import java.nio.IntBuffer; /** * Created by Administ ...
- jQuery Ajax使用总结
一.概述 jQuery对Ajax操作进行了封装,在jQuery中$.ajax()是属于最底层的方法,第2层是load().$.get()和$.post()方法,第三层是$.getScript()和$. ...
- WebUploader 上传插件结合bootstrap的模态框使用时选择上传文件按钮无效问题的解决方法
由于种种原因(工作忙,要锻炼健身,要看书,要学习其他兴趣爱好,谈恋爱等),博客已经好久没有更新,为这个内心一直感觉很愧疚,今天开始决定继续更新博客,每周至少一篇,最多不限篇幅. 今天说一下,下午在工作 ...
- Django框架_URLconf、Views、template、ORM
目录: 一.Django-MTV MTV模型 Django基本命令 视图层之路由配置系统(views) 视图层之视图函数(views) 模板层(template) 二.Django-model基础 O ...
- [笔记]Python中模块互相调用的例子
python中模块互相调用容易出错,经常是在本地路径下工作正常,切换到其他路径来调用,就各种模块找不到了. 解决方法是通过__file__定位当前文件的真实路径,再通过sys.path.append( ...
- 零基础学习openstack【完整中级篇】及openstack资源汇总
1.你是如何学习openstack的?2.你对openstack的组件了解多少?3.你认为openstack该如何学习? 一直想写关于openstack的方面的内容,今天终于整理完成.算是完成一桩心事 ...
- Use the SVN command-line tool
欢迎关注我的社交账号: 博客园地址: http://www.cnblogs.com/jiangxinnju/p/4781259.html GitHub地址: https://github.com/ji ...