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
./test6
./test4
./scf/lib
./scf/service/deploy/product
./scf/service/deploy/info
./scf/service/deploy
./scf/service
./scf/doc
./scf/bin
./scf
./test3
.
2.du,查看指定目录的所占空间
[root@localhost ~]$ du hadoop
hadoop/log/hive/kumufengchun
hadoop/log/hive
hadoop/log
hadoop
3.du,显示指定文件所占空间
[root@localhost ~]$ du test.sh
test.sh
4.du,显示多个文件所占空间
[root@localhost ~]$ du test.sh black.txt
test.sh
black.txt
5.du -s,只显示总和的大小
[root@localhost ~]$ du -s hadoop
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
log30.tar.gz
log31.tar.gz
总计
9.按照空间大小排序
[root@localhost test]# du|sort -nr|more
.
./test6
./test4
./scf
./scf/service
./scf/service/deploy
./test3
./scf/service/deploy/product
./scf/service/deploy/info
./scf/lib
./scf/doc
./scf/bin
10.输出当前目录下各个子目录所使用的空间
[root@localhost test]# du -h --max-depth=
608K ./test6
308K ./test4
32K ./scf
.0K ./test3
1.3M .
11.选项--exclude和--exclude-from可以让du在磁盘使用统计中排除部分文件
[root@localhost test]# du --exclude "*.txt" -a shell/
shell/ifs.sh
shell/TEST.TXT
shell/disklog.sh
shell/file.sh
shell/timing.log
shell/exit.sh
shell/.sh
3.df详解
linux中df命令是用来检查linux服务器的文件系统的磁盘占用空间情况。可以利用该命令来获取硬盘被占用了多少空间,母亲还剩下多少空间等信息
3.1命令格式
df [选项] [文件]
3.2命令功能
显示指定磁盘文件的可用空间。如果没有文件名被指定,则所有当前被挂载的文件系统的可用空间将被显示。默认情况下,磁盘空间将以 1KB 为单位进行显示,除非环境变量 POSIXLY_CORRECT 被指定,那样将以512字节为单位进行显示
3.3命令参数
必要参数:
-a 全部文件系统列表
-h 方便阅读方式显示
-H 等于“-h”,但是计算式,1K=,而不是1K=
-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 % /
/dev/sda9 % /opt
/dev/sda8 % /var
/dev/sda6 % /usr
/dev/sda3 % /boot
tmpfs % /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 % /
/dev/sda9 % /opt
/dev/sda8 % /var
/dev/sda6 % /usr
/dev/sda3 % /boot
tmpfs % /dev/shm
3.df -T,列出文件系统的类型
[root@CT1190 log]# df -T
文件系统 类型 1K-块 已用 可用 已用% 挂载点
/dev/sda7 ext3 % /
/dev/sda9 ext3 % /opt
/dev/sda8 ext3 % /var
/dev/sda6 ext3 % /usr
/dev/sda3 ext3 % /boot
tmpfs tmpfs % /dev/shm
4.显示指定类型磁盘
[root@CT1190 log]# df -t ext3
文件系统 1K-块 已用 可用 已用% 挂载点
/dev/sda7 % /
/dev/sda9 % /opt
/dev/sda8 % /var
/dev/sda6 % /usr
/dev/sda3 % /boot
5.列出各文件系统的i节点使用情况
[root@CT1190 log]# df -ia
文件系统 Inode (I)已用 (I)可用 (I)已用% 挂载点
/dev/sda7 %
/proc - /proc
sysfs - /sys
devpts - /dev/pts
/dev/sda9 % /opt
/dev/sda8 % /var
/dev/sda6 % /usr
/dev/sda3 % /boot
tmpfs % /dev/shm
none - /proc/sys/fs/binfmt_misc
6.以更易读的方式显示目前磁盘空间和使用情况
[root@CT1190 log]# df -h
文件系统 容量 已用 可用 已用% 挂载点
/dev/sda7 19G 871M 18G % /
/dev/sda9 195G 89G 96G % /opt
/dev/sda8 .8G 557M .0G % /var
/dev/sda6 19G .9G 17G % /usr
/dev/sda3 965M 24M 892M % /boot
tmpfs 16G 16G % /dev/shm
[root@CT1190 log]# df -H
文件系统 容量 已用 可用 已用% 挂载点
/dev/sda7 21G 913M 19G % /
/dev/sda9 209G 96G 103G % /opt
/dev/sda8 .1G 584M .3G % /var
/dev/sda6 21G .1G 18G % /usr
/ev/sda3 .1G 25M 936M % /boot
tmpfs 17G 17G % /dev/shm
[root@CT1190 log]# df -lh
文件系统 容量 已用 可用 已用% 挂载点
/dev/sda7 19G 871M 18G % /
/dev/sda9 195G 89G 96G % /opt
/dev/sda8 .8G 557M .0G % /var
/dev/sda6 19G .9G 17G % /usr
/dev/sda3 965M 24M 892M % /boot
tmpfs 16G 16G % /dev/shm
[root@CT1190 log]# df -k
文件系统 1K-块 已用 可用 已用% 挂载点
/dev/sda7 % /
/dev/sda9 % /opt
/dev/sda8 % /var
/dev/sda6 % /usr
/dev/sda3 % /boot
tmpfs % /dev/shm
说明:
-h更具目前磁盘空间和使用情况 以更易读的方式显示
-H根上面的-h参数相同,不过在根式化的时候,采用1000而不是1024进行容量转换
-k以单位显示磁盘的使用情况
-l显示本地的分区的磁盘空间使用率,如果服务器nfs了远程服务器的磁盘,那么在df上加上-l后系统显示的是过滤nsf驱动器后的结果
-i显示inode的使用情况。linux采用了类似指针的方式管理磁盘空间影射.这也是一个比较关键应用
原文连接 https://blog.csdn.net/wisgood/article/details/17316663
shell学习(9)- du和df区别及详解的更多相关文章
- WScript.Shell对象的 run()和exec()函数使用详解
WScript.Shell对象的 run()和exec()函数使用详解 http://blog.sina.com.cn/s/blog_6e14a2050102v47g.html vbScript ...
- Windows8 各种版本区别对比详解
微软的 Windows8 操作系统提供了4个不同的版本,分别是 Windows RT.Windows 8 标准版.Windows 8 Pro 专业版 以及 Windows 8 Enterprise 企 ...
- Linux防火墙iptables学习笔记(三)iptables命令详解和举例[转载]
Linux防火墙iptables学习笔记(三)iptables命令详解和举例 2008-10-16 23:45:46 转载 网上看到这个配置讲解得还比较易懂,就转过来了,大家一起看下,希望对您工作能 ...
- ASP.NET MVC 5 学习教程:Details 和 Delete 方法详解
原文 ASP.NET MVC 5 学习教程:Details 和 Delete 方法详解 在教程的这一部分,我们将研究一下自动生成的 Details 和Delete 方法. Details 方法 打开M ...
- Linux Shell脚本入门--wget 命令用法详解
Linux Shell脚本入门--wget 命令用法详解 wget是在Linux下开发的开放源代码的软件,作者是Hrvoje Niksic,后来被移植到包括Windows在内的各个平台上.它有以下功能 ...
- 基于OpenCL的深度学习工具:AMD MLP及其使用详解
基于OpenCL的深度学习工具:AMD MLP及其使用详解 http://www.csdn.net/article/2015-08-05/2825390 发表于2015-08-05 16:33| 59 ...
- (转)live555学习笔记10-h264 RTP传输详解(2)
参考: 1,live555学习笔记10-h264 RTP传输详解(2) http://blog.csdn.net/niu_gao/article/details/6936108 2,H264 sps ...
- java中4种修饰符访问权限的区别及详解全过程
java中4种修饰符访问权限的区别及详解全过程 http://jingyan.baidu.com/article/fedf0737700b3335ac8977ca.html java中4中修饰符分别为 ...
- Java日志管理:Logger.getLogger()和LogFactory.getLog()的区别(详解Log4j)
Java日志管理:Logger.getLogger()和LogFactory.getLog()的区别(详解Log4j) 博客分类: Java综合 第一.Logger.getLogger()和Log ...
随机推荐
- 《机器学习实战》学习笔记第三章 —— 决策树之ID3、C4.5算法
主要内容: 一.决策树模型 二.信息与熵 三.信息增益与ID3算法 四.信息增益比与C4.5算法 五.决策树的剪枝 一.决策树模型 1.所谓决策树,就是根据实例的特征对实例进行划分的树形结构.其中有两 ...
- Linux学习之路(三)搜索命令
1.文件搜索命令locate 2.命令搜索命令whereis与which 3.字符串搜索命令grep 4.find命令与grep命令的区别 locate命令相对于find命令搜索非常快,find命令在 ...
- unable to create new native thread 问题
ulimit -a ulimit -a core file size (blocks, -c) 0 data seg size (kbytes, -d) unlimited scheduling pr ...
- 「LuoguP1725」琪露诺(dp 单调队列
题目描述 在幻想乡,琪露诺是以笨蛋闻名的冰之妖精. 某一天,琪露诺又在玩速冻青蛙,就是用冰把青蛙瞬间冻起来.但是这只青蛙比以往的要聪明许多,在琪露诺来之前就已经跑到了河的对岸.于是琪露诺决定到河岸去追 ...
- 【Lintcode】017.Subsets
题目: 题解: Solution 1 () class Solution { public: vector<vector<int> > subsets(vector<in ...
- 【LeetCode】040. Combination Sum II
题目: Given a collection of candidate numbers (C) and a target number (T), find all unique combination ...
- Asp.Net 无法获取IIS拾取目录的解决办法[译]
Asp.Net 无法获取IIS拾取目录的解决办法 作者:Jason Doucette [MCP] 翻译:彭远志 原文地址:Fixing the cannot get IIS pickup direc ...
- 物联网项目开发必读 深度分析MQTT协议优缺点
物联网并不仅仅是一种网络,而是一个新的生态环境,它描述的本质是越来越多的使用物品通过网络连接在一起并可使用单个或者多个的终端设备对它们进行各种控制和使用—当然,工业上的物联网通常连接到的石鼓传感器或者 ...
- Java面试知识点总结(1)
1.Java中的原始数据类型都有哪些,它们的大小及对应的封装类是什么? 原始数据类型 大小(byte) 对应封装类型 boolean 1或4 Boolean byte 1 Byte short 2 S ...
- 解决Visual Code安装中文插件失败问题
早已听闻Visual Code的大名,今日一用,果然不同凡响. 只不过,我的常用开发环境是不联网的,需要离线安装Visual Code和扩展插件. 以前要安装插件只能从VsCode里装,想离线安装比较 ...