|
|
当磁盘大小超过标准时会有报警提示,这时如果掌握df和du命令是非常明智的选择。
; _2 p4 L# B6 ^5 b+ U3 S2 [- r7 r0 s" h1 t
df可以查看一级文件夹大小、使用比例、档案系统及其挂入点,但对文件却无能为力。
: W0 z3 _6 J8 n* G du可以查看文件及文件夹的大小。9 J% h3 ~* q: _% W6 t$ D
) j1 ?$ h. @( c
两者配合使用,非常有效。比如用df查看哪个一级目录过大,然后用df查看文件夹或文件的大小,如此便可迅速确定症结。7 e5 t9 F* e7 [7 a) t8 K# X
# O, n8 U: |& m z( t 下面分别简要介绍' V( u6 f, r+ W' q
, A6 {/ a& s' ]8 F
df命令可以显示目前所有文件系统的可用空间及使用情形,请看下列这个例子: r6 q8 l% y+ O& j3 [$ y$ ?: t/ j
7 b. N' V* m/ \以下是代码片段:. b1 M# S$ b1 Y9 x, Y) T
3 i" m! Q: `+ ] \8 \8 ]7 l* s/ \0 a[yayug@yayu ~]$ df -h9 E7 A- K- H0 F6 H6 Q6 q7 w% z* I
Filesystem Size Used Avail Use% Mounted on2 R9 g2 e* r" K; E' [! w
/dev/sda1 3.9G 300M 3.4G 8% /, q1 S/ i6 b8 g' `0 y0 F
/dev/sda7 100G 188M 95G 1% /data0
) {/ p0 R* m5 ~2 j7 T; D- l( j/dev/sdb1 133G 80G 47G 64% /data1
% y7 q5 o* Q! G4 E8 `2 o& ?4 N/dev/sda6 7.8G 218M 7.2G 3% /var
) O2 k0 ?' a5 s; e) A. ]- g. K; u/dev/sda5 7.8G 166M 7.2G 3% /tmp
' F) v: I: R: q8 g$ k% O6 Q/dev/sda3 9.7G 2.5G 6.8G 27% /usr
! y5 a4 L2 @1 ~1 H: g$ z7 ] U3 J0 Dtmpfs 2.0G 0 2.0G 0% /dev/shm0 j/ G( d1 T1 \5 i0 |
7 i7 e% I4 X8 b 参数 -h 表示使用「Human-readable」的输出,也就是在档案系统大小使用 GB、MB 等易读的格式。
. M B& I$ D9 l9 m& |1 ]) ?. h; T) d) J0 q# M$ n9 P
上面的命令输出的第一个字段(Filesystem)及最后一个字段(Mounted on)分别是档案系统及其挂入点。我们可以看到 /dev/sda1 这个分割区被挂在根目录下。. y( u$ ~- A1 \0 k
- B, }1 d( w1 r0 Z9 T1 `
接下来的四个字段 Size、Used、Avail、及 Use% 分别是该分割区的容量、已使用的大小、剩下的大小、及使用的百分比。 FreeBSD下,当硬盘容量已满时,您可能会看到已使用的百分比超过 100%,因为 FreeBSD 会留一些空间给 root,让 root 在档案系统满时,还是可以写东西到该档案系统中,以进行管理。5 w% I& x: h+ a x) z. K
5 X4 Y$ K+ |' N+ V! s" G. z
du:查询文件或文件夹的磁盘使用空间
! N( s( e0 q [/ J, A
0 ]+ `1 s4 E! q3 h1 x% S' C 如果当前目录下文件和文件夹很多,使用不带参数du的命令,可以循环列出所有文件和文件夹所使用的空间。这对查看究竟是那个地方过大是不利的,所以得指定深入目录的层数,参数:--max-depth=,这是个极为有用的参数!如下,注意使用“*”,可以得到文件的使用空间大小.6 l. O/ y1 q) D$ _, m+ `
8 P3 M- `1 z) e( h3 a: _ 提醒:一向命令比linux复杂的FreeBSD,它的du命令指定深入目录的层数却是比linux简化,为 -d。4 r( |1 L! d7 }$ d% M# V6 H( B- f1 H3 Y
+ o0 g$ e/ u9 V. s: C# X, A4 Y @
以下是代码片段:
0 G0 {# t" n9 l+ B; G
; y8 I" o" R$ Y' M& s: r[root@bsso yayu]# du -h --max-depth=1 work/testing
' I. z# v* J/ K. F) R. u2 W2 a27M work/testing/logs" E1 v' z5 V# ^/ k0 G) U! M' v3 b
35M work/testing# B& ^' u3 n: T+ p+ A1 E
$ R" H' E2 }- f[root@bsso yayu]# du -h --max-depth=1 work/testing/*
/ r! i+ ~( L4 L8 B8.0K work/testing/func.php
# ^8 ?/ d2 I9 _" l27M work/testing/logs0 m" ]* ^5 k. Y4 ]( B9 ]
8.1M work/testing/nohup.out
( m3 ?; g* t3 s+ r. i \8.0K work/testing/testing_c.php, T6 ~. x f5 Z9 p3 W9 x
12K work/testing/testing_func_reg.php7 b* p2 a, R) |- [
8.0K work/testing/testing_get.php# c# d. y5 D7 {' X
8.0K work/testing/testing_g.php- @8 z- B. |3 y/ |5 o
8.0K work/testing/var.php+ k% y+ D9 S1 X1 H5 N) o4 U
& c9 X3 G1 w) d3 B G$ }[root@bsso yayu]# du -h --max-depth=1 work/testing/logs/
0 u% ~/ A8 P4 h7 l+ e( G27M work/testing/logs/
- D3 J S7 m! |" d: O4 d9 I+ z3 L* ^% m$ h8 }
[root@bsso yayu]# du -h --max-depth=1 work/testing/logs/*( h0 k' {/ ` q9 N& ?, Z ^
24K work/testing/logs/errdate.log_show.log
; H8 S/ Y% r* f8.0K work/testing/logs/pertime_show.log% t* O& ^7 k1 A# ?
27M work/testing/logs/show.log4 s$ m3 g8 @& O
# |, q! I- q' ~& _7 c |
|