|
|
当磁盘大小超过标准时会有报警提示,这时如果掌握df和du命令是非常明智的选择。
) t4 H5 V) O) C+ u5 o
/ r3 A7 {3 W! s g* Q( [, Y df可以查看一级文件夹大小、使用比例、档案系统及其挂入点,但对文件却无能为力。
- X( g; A- E; e" G9 C" [9 H du可以查看文件及文件夹的大小。- X' c& E- c7 ~. S
?! @2 u" f) v6 @2 v8 N 两者配合使用,非常有效。比如用df查看哪个一级目录过大,然后用df查看文件夹或文件的大小,如此便可迅速确定症结。
" {8 z; s& n+ G% b+ q6 l6 r9 Y4 a$ I1 b$ R! C+ |
下面分别简要介绍
# y& P! M" W+ V m$ p. A5 r/ {0 \% W$ z% h" p* q% T- ~( b. G* x0 V
df命令可以显示目前所有文件系统的可用空间及使用情形,请看下列这个例子:
5 E: j' w( k) a9 ?
% V8 s$ N8 S5 p9 _以下是代码片段:$ F3 J" H- Y" K" B
! l4 _6 s' d% x! J3 Z1 W% }8 F2 r[yayug@yayu ~]$ df -h
3 Y% Z6 s- ]4 z5 x& z/ aFilesystem Size Used Avail Use% Mounted on0 j8 | r; e# F3 S1 z
/dev/sda1 3.9G 300M 3.4G 8% /0 I4 N( V" R* B
/dev/sda7 100G 188M 95G 1% /data01 C r' X6 m5 E- `1 b
/dev/sdb1 133G 80G 47G 64% /data1# h# U* T% r* {! L
/dev/sda6 7.8G 218M 7.2G 3% /var
6 z3 P4 d7 a( m) ?5 R6 B/dev/sda5 7.8G 166M 7.2G 3% /tmp9 p2 c1 ]& N6 J" e% T* k
/dev/sda3 9.7G 2.5G 6.8G 27% /usr2 V& \4 G( \4 S# l
tmpfs 2.0G 0 2.0G 0% /dev/shm- Z! k* b( I' {8 S- D
1 L$ l( l" i1 a* f; b
参数 -h 表示使用「Human-readable」的输出,也就是在档案系统大小使用 GB、MB 等易读的格式。
2 y: \! U6 E5 E! r- g
M1 @7 H+ ?- D- Z% g4 z 上面的命令输出的第一个字段(Filesystem)及最后一个字段(Mounted on)分别是档案系统及其挂入点。我们可以看到 /dev/sda1 这个分割区被挂在根目录下。$ V; s3 U6 z3 ]' u8 a# j/ `
8 {. V' s. d' m$ P/ I* X
接下来的四个字段 Size、Used、Avail、及 Use% 分别是该分割区的容量、已使用的大小、剩下的大小、及使用的百分比。 FreeBSD下,当硬盘容量已满时,您可能会看到已使用的百分比超过 100%,因为 FreeBSD 会留一些空间给 root,让 root 在档案系统满时,还是可以写东西到该档案系统中,以进行管理。1 c; f! g) M8 d+ T- C
# T8 `! I9 C# _7 S9 w8 j du:查询文件或文件夹的磁盘使用空间3 K% g, k* f+ L2 T5 N; f+ \' R
9 M: q! w" `9 p; q* ^
如果当前目录下文件和文件夹很多,使用不带参数du的命令,可以循环列出所有文件和文件夹所使用的空间。这对查看究竟是那个地方过大是不利的,所以得指定深入目录的层数,参数:--max-depth=,这是个极为有用的参数!如下,注意使用“*”,可以得到文件的使用空间大小.
- t: g2 s( {8 x8 C! F3 w$ z2 k5 b* S |) M
提醒:一向命令比linux复杂的FreeBSD,它的du命令指定深入目录的层数却是比linux简化,为 -d。
4 S4 v8 j" ]) ~* e( k6 O' B9 q5 p# I j
以下是代码片段:
6 N& |: |3 n2 w8 t* z6 i
: s$ [& Q/ ^( c+ o5 i[root@bsso yayu]# du -h --max-depth=1 work/testing, N- g. i9 g* z# x
27M work/testing/logs
/ x1 Y) l7 b1 Z" N( j35M work/testing
; B* X8 u! O+ Q8 z0 i9 Y0 Q7 o" P. ^1 i) u5 n; \: Q( ]* X6 w
[root@bsso yayu]# du -h --max-depth=1 work/testing/*; F( Y7 e. J) S
8.0K work/testing/func.php
3 V; Z# r" B! C5 P6 a+ o+ s* H; }4 n4 @7 g27M work/testing/logs1 z% E( f1 H2 S% [
8.1M work/testing/nohup.out
) \, _# ?/ S& R- C% ?8.0K work/testing/testing_c.php
2 y' p8 E* G" K3 ?. u- _7 u1 Q12K work/testing/testing_func_reg.php& L X9 k1 q9 ^' c; D, N* t- A
8.0K work/testing/testing_get.php! u* e- K9 B7 o
8.0K work/testing/testing_g.php
( s& ` m- F" V+ `7 z$ R8.0K work/testing/var.php* `; \) G! l7 T" ^4 J1 }
9 D- M4 i9 ]* o0 y) a[root@bsso yayu]# du -h --max-depth=1 work/testing/logs/
- o) x J0 p& u; R8 D- x27M work/testing/logs/
2 J# a, }9 ]9 ~/ }3 g5 o" I( _2 z. l
[root@bsso yayu]# du -h --max-depth=1 work/testing/logs/*& O* U- K& Q; S$ k& q+ B8 x
24K work/testing/logs/errdate.log_show.log
7 L" _2 ]/ t- L7 ~5 Q8.0K work/testing/logs/pertime_show.log
9 w- {, `8 f0 k4 N- Q27M work/testing/logs/show.log
$ R% }4 B" G+ k
) y( e' O; C" Y6 d0 ~# y/ w: j" g |
|