|
当磁盘大小超过标准时会有报警提示,这时如果掌握df和du命令是非常明智的选择。* \( J6 Y' d S
& a8 u p! q _; ~' i: m2 _, o df可以查看一级文件夹大小、使用比例、档案系统及其挂入点,但对文件却无能为力。2 v6 S) ?! E/ t" V& k& z6 Y% ^% A
du可以查看文件及文件夹的大小。
: Y6 X* W/ ^5 N7 w8 e8 |# D! s; R' D9 |
两者配合使用,非常有效。比如用df查看哪个一级目录过大,然后用df查看文件夹或文件的大小,如此便可迅速确定症结。
% I! d# m1 y+ A3 p! D4 k) [1 p0 ^
4 l& t9 v+ n8 l0 S+ }% J 下面分别简要介绍
6 Y" I% P3 a, R% C7 n% e5 }1 l7 |
df命令可以显示目前所有文件系统的可用空间及使用情形,请看下列这个例子:
1 ~0 S8 ]1 q8 I. e$ Y. _7 l, K9 k+ T% e( J& v+ |3 T
以下是代码片段:/ q( Q, ~1 e# T# M4 {, G8 o; j
0 Y7 p; X i5 \5 I5 @. ?0 o[yayug@yayu ~]$ df -h& F9 {$ x; z: P+ R. \1 y* X
Filesystem Size Used Avail Use% Mounted on+ s% M% i5 @8 n: ]' W. |! R+ D9 j
/dev/sda1 3.9G 300M 3.4G 8% /
I; T% C/ _; c2 A% j- C. ~/dev/sda7 100G 188M 95G 1% /data0 k/ F5 z8 h8 i* F" ~$ L# T" r
/dev/sdb1 133G 80G 47G 64% /data1+ Z5 f3 C5 A5 W8 T% {/ G
/dev/sda6 7.8G 218M 7.2G 3% /var8 Q2 V- ^) R6 M; g. z( t
/dev/sda5 7.8G 166M 7.2G 3% /tmp) C$ J& z: {! Y+ \2 @, n# J' w
/dev/sda3 9.7G 2.5G 6.8G 27% /usr
2 D# x9 N1 ?$ k! I1 rtmpfs 2.0G 0 2.0G 0% /dev/shm
" O! V% i' L4 w! l. B
4 z9 ~5 X- l( m- l- I' e6 R( u 参数 -h 表示使用「Human-readable」的输出,也就是在档案系统大小使用 GB、MB 等易读的格式。# F; R7 n" [6 I0 w" ^
`1 e9 E" I) Q) p' v- N' W/ b# y
上面的命令输出的第一个字段(Filesystem)及最后一个字段(Mounted on)分别是档案系统及其挂入点。我们可以看到 /dev/sda1 这个分割区被挂在根目录下。5 V: s2 v! o. c! ~' `
; [0 O) _; T9 G$ P! k% I" R2 P6 M
接下来的四个字段 Size、Used、Avail、及 Use% 分别是该分割区的容量、已使用的大小、剩下的大小、及使用的百分比。 FreeBSD下,当硬盘容量已满时,您可能会看到已使用的百分比超过 100%,因为 FreeBSD 会留一些空间给 root,让 root 在档案系统满时,还是可以写东西到该档案系统中,以进行管理。
8 @: H: e0 X) a; }0 h1 V8 a5 a9 l3 j1 a2 }7 \
du:查询文件或文件夹的磁盘使用空间
+ y4 k" Y: J' I) a q9 E
3 K+ B* X5 s3 s: p4 ]4 e: f# I 如果当前目录下文件和文件夹很多,使用不带参数du的命令,可以循环列出所有文件和文件夹所使用的空间。这对查看究竟是那个地方过大是不利的,所以得指定深入目录的层数,参数:--max-depth=,这是个极为有用的参数!如下,注意使用“*”,可以得到文件的使用空间大小.
. b. @( @! U: ~. C4 n1 f3 C5 f) |$ ?$ R' Z" X+ k% }
提醒:一向命令比linux复杂的FreeBSD,它的du命令指定深入目录的层数却是比linux简化,为 -d。+ ^$ _6 }: q5 z% ~
, N, R) C$ R. Q以下是代码片段:% X9 G+ f- M6 S( O& c4 N8 o4 m: ?- K
, ]4 g' K K* N6 p9 ~' x+ I. V+ A
[root@bsso yayu]# du -h --max-depth=1 work/testing: b4 X1 ^ |/ V+ Z" @" V( }. g
27M work/testing/logs6 N7 j5 u+ q w6 P% D5 C
35M work/testing H- d3 v8 e0 T1 R- ?
7 n7 K3 t) p) t; M% a$ X[root@bsso yayu]# du -h --max-depth=1 work/testing/*) z i$ K5 `2 [2 e8 Z
8.0K work/testing/func.php
7 k8 J) o% M5 N' \: M27M work/testing/logs
( {9 B9 @. @* n0 o2 G8.1M work/testing/nohup.out
0 F+ N+ i$ y/ H- v9 j8.0K work/testing/testing_c.php
" p8 ?* c1 k$ s12K work/testing/testing_func_reg.php% z Q8 g( L# G+ Q0 c
8.0K work/testing/testing_get.php
8 c8 k8 ^- x6 e; z) I: j$ [* |: z8.0K work/testing/testing_g.php6 I6 C' K h ~3 j. ?
8.0K work/testing/var.php% r6 W3 D$ i: A G& j* `
3 ]$ t( }* t) e
[root@bsso yayu]# du -h --max-depth=1 work/testing/logs/
c' O% Z' [$ n8 Y# k" |27M work/testing/logs/
& q! ?3 I1 T. U' e: I% t- H5 x9 u3 N- j c
[root@bsso yayu]# du -h --max-depth=1 work/testing/logs/*
" o' k& K5 s4 g% V7 I- r: v) e. l24K work/testing/logs/errdate.log_show.log
' M9 |; G; m1 r% [8.0K work/testing/logs/pertime_show.log$ t8 c6 w2 y( s9 z) ]5 P1 F6 ?5 b& b* L% C
27M work/testing/logs/show.log9 Z/ y( A- g* w7 W) P1 Y6 z
0 g. y+ v6 z5 l' G) ^
|
|