|
当磁盘大小超过标准时会有报警提示,这时如果掌握df和du命令是非常明智的选择。. l: T$ Z, h5 {- e
% F# U0 e" X9 p3 w. w/ w5 E/ S" _ df可以查看一级文件夹大小、使用比例、档案系统及其挂入点,但对文件却无能为力。, R, d7 T, n8 ?
du可以查看文件及文件夹的大小。
1 R! c9 S% k0 {. s+ ?) Z
& O) D; n! ^- p3 a$ \1 M1 T5 e 两者配合使用,非常有效。比如用df查看哪个一级目录过大,然后用df查看文件夹或文件的大小,如此便可迅速确定症结。$ g# n# }* S c8 U; f
% u9 G& ~$ f& p2 o7 Z% S1 | 下面分别简要介绍$ N1 P/ \; L# o/ a. j7 G
. [# ^" `5 s9 C% i! y df命令可以显示目前所有文件系统的可用空间及使用情形,请看下列这个例子:
* o! ~4 d) h( V! {" g. |" h
0 f) i. }. w1 B" T以下是代码片段:) v0 K5 G; l' h+ h4 K7 j
( L- [9 [9 L# ? _; u9 H[yayug@yayu ~]$ df -h$ Z& U, |8 H+ c7 |: T
Filesystem Size Used Avail Use% Mounted on
+ V5 G: z# M2 ^- C' H: s. R; E/dev/sda1 3.9G 300M 3.4G 8% /
; @ \8 p& H. u/ a* Z6 a7 I; p4 o/dev/sda7 100G 188M 95G 1% /data0" W+ S0 c+ o: s" F( H( k" Z
/dev/sdb1 133G 80G 47G 64% /data1
9 s3 n. _7 |4 }2 g/ K5 T( G/dev/sda6 7.8G 218M 7.2G 3% /var
( X8 h5 G6 }# Y/dev/sda5 7.8G 166M 7.2G 3% /tmp( a/ z4 ]( F0 Z2 M# m0 A9 _
/dev/sda3 9.7G 2.5G 6.8G 27% /usr
U: H6 q4 X# n" U2 Otmpfs 2.0G 0 2.0G 0% /dev/shm( W. Q& b- _/ C. h/ l
2 U, K. w+ r7 Y 参数 -h 表示使用「Human-readable」的输出,也就是在档案系统大小使用 GB、MB 等易读的格式。
' i9 E6 N* v4 {% O" m. l2 w8 [
% f; N/ M3 h0 q# g+ a8 Y 上面的命令输出的第一个字段(Filesystem)及最后一个字段(Mounted on)分别是档案系统及其挂入点。我们可以看到 /dev/sda1 这个分割区被挂在根目录下。% |( ]! d) _$ i
) ^) q- [( K; Y2 }) y" q" g
接下来的四个字段 Size、Used、Avail、及 Use% 分别是该分割区的容量、已使用的大小、剩下的大小、及使用的百分比。 FreeBSD下,当硬盘容量已满时,您可能会看到已使用的百分比超过 100%,因为 FreeBSD 会留一些空间给 root,让 root 在档案系统满时,还是可以写东西到该档案系统中,以进行管理。3 N( e5 o3 I0 q* @
7 \, z4 f7 r. @6 y; m4 @
du:查询文件或文件夹的磁盘使用空间
- b1 ]! ^+ w# b! H% b! ~+ \. K6 q( Z" \. f
如果当前目录下文件和文件夹很多,使用不带参数du的命令,可以循环列出所有文件和文件夹所使用的空间。这对查看究竟是那个地方过大是不利的,所以得指定深入目录的层数,参数:--max-depth=,这是个极为有用的参数!如下,注意使用“*”,可以得到文件的使用空间大小.
/ B% }5 ~. c9 J) ?" b3 R0 e0 m. ?0 q/ d% ?, u
提醒:一向命令比linux复杂的FreeBSD,它的du命令指定深入目录的层数却是比linux简化,为 -d。
3 X1 p- l R0 J0 _1 [0 E4 F% W9 {- g2 }+ ~
以下是代码片段:1 m5 f* W4 J- ]( u
. z7 x* I% d q- J[root@bsso yayu]# du -h --max-depth=1 work/testing
5 V; _, E- d8 ]; I" ]7 a27M work/testing/logs
; {. d3 |, O. D# {. }35M work/testing/ b8 Z4 h, D: j, S3 m* g
& Z0 w4 h2 K+ B8 I$ u; M8 D
[root@bsso yayu]# du -h --max-depth=1 work/testing/*
d8 L$ K0 S: ~, B, {3 X5 s5 s8.0K work/testing/func.php: j# V* ]; X( l
27M work/testing/logs5 z; v9 `" u2 {# g/ q5 {8 c
8.1M work/testing/nohup.out0 {+ u- k0 w, [+ h$ K
8.0K work/testing/testing_c.php8 u$ |' @2 d7 {
12K work/testing/testing_func_reg.php- S% K3 E% X( W$ ^
8.0K work/testing/testing_get.php. G2 l+ _$ q+ B+ ^8 W( D" u
8.0K work/testing/testing_g.php3 T2 |) p% g' E+ k% \) p9 R
8.0K work/testing/var.php
- E5 J- s2 J% Q# j. n; r6 C ~) S& E" T2 H( d2 t
[root@bsso yayu]# du -h --max-depth=1 work/testing/logs/
6 o7 I- r. L' U27M work/testing/logs/
e) z g4 |& T' v6 S- r
6 k" u/ H2 K* Q: J$ W+ Z( i[root@bsso yayu]# du -h --max-depth=1 work/testing/logs/*1 J" `. z6 c" t5 o: O
24K work/testing/logs/errdate.log_show.log3 s! D: ^8 W2 `
8.0K work/testing/logs/pertime_show.log
" ~8 @; S6 x/ r! S27M work/testing/logs/show.log6 {0 S: l8 O9 |2 I
2 D- c4 _! D% n/ w3 n3 C |
|