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.命令功能 ...
随机推荐
- javascript 之 valueOf
var m = { i:10, toString:function () { console.log('toString'); return this.i; }, valueOf:function ( ...
- Spark2.0机器学习系列之3:决策树
概述 分类决策树模型是一种描述对实例进行分类的树形结构. 决策树可以看为一个if-then规则集合,具有“互斥完备”性质 .决策树基本上都是 采用的是贪心(即非回溯)的算法,自顶向下递归分治构造. 生 ...
- springboot使用tomcat apr模式
因需项目对并发要求比较高.提高Tomcat效率.使用tomcat apr模式.今天在这记录下使用过程.apr全称为apache portable runtime.这里套用下wiki对apr的解释. T ...
- shell脚本循环处理文件数据
有一个日志文件为: # cat data.log 需要提取出里面的数据,写shell脚本实现这个功能: #!/bin/bash OLD=$IFS IFS=$'\n' for entry in $(ca ...
- SDUT3146:Integer division 2(整数划分区间dp)
题目:传送门 题目描述 This is a very simple problem, just like previous one. You are given a postive integer n ...
- 6 TensorFlow实现cnn识别手写数字
------------------------------------ 写在开头:此文参照莫烦python教程(墙裂推荐!!!) ---------------------------------- ...
- Ajax跨域请求 同源策略与Jsonp
同源策略 同源策略(Same origin policy)是一种约定,它是浏览器最核心也最基本的安全功能,如果缺少了同源策略,则浏览器的正常功能可能都会受到影响.可以说Web是构建在同源策略基础之上的 ...
- Zen Cart屏蔽中文语言浏览器
在根目录下的index.php前面加上以下这段代码即可: if(preg_match("/zh-cn/is",$_SERVER['HTTP_ACCEPT_LANGUAGE'])){ ...
- mac shell
查看所有shell:cat /etc/shells 查看当前正在使用的shell:echo $SHELL 切换shell:chsh -s /bin/zsh
- 树莓派搭建Git服务器
目录 安装ssh 安装git-core 新增git用户 设置git用户目录 [服务端]设置git仓库 [客户端]设置git仓库 设置ssh登录 安装ssh sudo apt-get install s ...