|
|
当磁盘大小超过标准时会有报警提示,这时如果掌握df和du命令是非常明智的选择。
0 J! p9 ^( \4 K7 V! C
) B" d& g5 O& T r- `3 ]( } df可以查看一级文件夹大小、使用比例、档案系统及其挂入点,但对文件却无能为力。+ _* ~7 u3 h3 z/ c8 N
du可以查看文件及文件夹的大小。& c7 X# T0 |4 G. n( R4 t
$ y' @. b* U& Y, z/ y! P 两者配合使用,非常有效。比如用df查看哪个一级目录过大,然后用df查看文件夹或文件的大小,如此便可迅速确定症结。1 [9 l/ m4 Z, i8 V2 Y' T
. b2 u4 c$ z; j' u
下面分别简要介绍
- e& x3 |5 v- _' {" m# R8 v% @7 r1 i9 P
df命令可以显示目前所有文件系统的可用空间及使用情形,请看下列这个例子:
) e) q% ~1 j5 ^6 I: v- g/ p" V7 a* c0 w$ v) {% h& a
以下是代码片段:
0 O, i2 d. C8 F4 U$ Y$ x" v8 u+ o
4 s" P3 X0 Z. t[yayug@yayu ~]$ df -h
0 V) [% c4 e! A. {- j3 ~Filesystem Size Used Avail Use% Mounted on
# b. B+ p4 o$ L8 d2 t; K/dev/sda1 3.9G 300M 3.4G 8% /' y9 T& R% w6 ]1 u
/dev/sda7 100G 188M 95G 1% /data0
7 Z8 P4 X$ ?2 }0 H8 I- I/dev/sdb1 133G 80G 47G 64% /data1
9 ^- o6 L5 g, [6 d/dev/sda6 7.8G 218M 7.2G 3% /var
2 c; n6 D5 ~, l% J3 C1 ?* ]( m" T0 U/dev/sda5 7.8G 166M 7.2G 3% /tmp
# F3 d) o( ]6 l- [/dev/sda3 9.7G 2.5G 6.8G 27% /usr
/ W/ b$ ?6 u( \) S/ u$ o% Xtmpfs 2.0G 0 2.0G 0% /dev/shm2 J5 H: [4 l' y5 a
+ l2 p. O/ F7 d
参数 -h 表示使用「Human-readable」的输出,也就是在档案系统大小使用 GB、MB 等易读的格式。* N; v3 U) u3 Y# K
* z X: d6 `% E# }! G
上面的命令输出的第一个字段(Filesystem)及最后一个字段(Mounted on)分别是档案系统及其挂入点。我们可以看到 /dev/sda1 这个分割区被挂在根目录下。
1 V) }7 j$ e- J$ O/ g4 D6 d4 t: `6 N' Z% m( C
接下来的四个字段 Size、Used、Avail、及 Use% 分别是该分割区的容量、已使用的大小、剩下的大小、及使用的百分比。 FreeBSD下,当硬盘容量已满时,您可能会看到已使用的百分比超过 100%,因为 FreeBSD 会留一些空间给 root,让 root 在档案系统满时,还是可以写东西到该档案系统中,以进行管理。
+ T3 [1 n+ D8 E0 m" o. B9 ?6 O' F" p% F; B# }7 ]& B* ]
du:查询文件或文件夹的磁盘使用空间
1 \' d6 H2 {0 S# _. \/ Z
2 M3 B) P+ [! @( J% X 如果当前目录下文件和文件夹很多,使用不带参数du的命令,可以循环列出所有文件和文件夹所使用的空间。这对查看究竟是那个地方过大是不利的,所以得指定深入目录的层数,参数:--max-depth=,这是个极为有用的参数!如下,注意使用“*”,可以得到文件的使用空间大小." }0 a; [( t6 c2 e$ h3 |
' t! L! @. w- y6 f9 h# `' B
提醒:一向命令比linux复杂的FreeBSD,它的du命令指定深入目录的层数却是比linux简化,为 -d。
( `1 g7 q3 a( O
3 }4 {" ^; L& @, [/ Y以下是代码片段:
0 x2 u$ I( m. A% s I6 d6 c) u+ W3 `6 {& p
[root@bsso yayu]# du -h --max-depth=1 work/testing
/ E+ r/ p: V- D M* d# J0 s% T27M work/testing/logs: |3 M x/ q* g' C" k
35M work/testing# W9 b- Y! @; l" j/ v
2 G$ P& X4 X( _' Y, [- T: H
[root@bsso yayu]# du -h --max-depth=1 work/testing/*
7 t1 E) d- N6 _. o( G: e8.0K work/testing/func.php
/ E6 D1 C) V) H5 ^7 Z27M work/testing/logs
, o/ M) l5 W0 T0 g' W7 J8.1M work/testing/nohup.out
9 D3 o- M7 M- i2 X, \+ k8.0K work/testing/testing_c.php
' P( }1 I7 _- f/ D, y$ B12K work/testing/testing_func_reg.php
1 Q! u' n% I$ [8.0K work/testing/testing_get.php
: {1 N6 S9 G! }3 ?, L+ C( f8.0K work/testing/testing_g.php
( y ~+ M+ m# s+ H8.0K work/testing/var.php9 o2 v; q) x" i/ @' F, ?: P) a- n
/ C4 ] c4 u# Y; i- n[root@bsso yayu]# du -h --max-depth=1 work/testing/logs/
! c- a4 H8 p" b' k27M work/testing/logs/
2 G1 T$ r$ s0 E7 L8 [. g" }9 L2 V7 R5 }
[root@bsso yayu]# du -h --max-depth=1 work/testing/logs/*7 k! v7 n9 T/ W
24K work/testing/logs/errdate.log_show.log) d! z @ x5 _5 x( d" D; s
8.0K work/testing/logs/pertime_show.log( `4 k: k) d5 K
27M work/testing/logs/show.log
/ `# ]6 Z; f' o
6 C$ H" T! O4 G( i! i8 b |
|