清明小长假来加班,总得干点啥吧,今天就说说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 .
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