|
|
当磁盘大小超过标准时会有报警提示,这时如果掌握df和du命令是非常明智的选择。
|7 H! Z8 h. N4 V5 p+ D) J: ^- O7 b; Q
df可以查看一级文件夹大小、使用比例、档案系统及其挂入点,但对文件却无能为力。4 o1 [* }) b8 A* E* Z" T1 Z+ E; w
du可以查看文件及文件夹的大小。
2 R2 y1 d" `. x7 X/ @7 x3 ?: e* M4 U* w1 a1 s. K) Z& C
两者配合使用,非常有效。比如用df查看哪个一级目录过大,然后用df查看文件夹或文件的大小,如此便可迅速确定症结。
# K! s( f" h( u2 w0 l- q6 L6 o$ X# Y M) K* k) |5 ~6 M/ g8 u! j
下面分别简要介绍+ X5 b" ]# S% l! y
9 @$ p5 P9 l c$ m( F df命令可以显示目前所有文件系统的可用空间及使用情形,请看下列这个例子:
' x- m+ n) w- O4 y; U5 P. B4 y5 V- B" O3 W4 T0 F+ Q4 M
以下是代码片段:
1 _) e; I0 r5 l; y
' G! m* e- Y$ i5 z) u9 v* ^# ^+ F[yayug@yayu ~]$ df -h8 g+ d E+ {+ [5 |' @
Filesystem Size Used Avail Use% Mounted on3 t- n# e* a, H$ N
/dev/sda1 3.9G 300M 3.4G 8% /
4 j/ [6 E) n+ q+ R4 i/dev/sda7 100G 188M 95G 1% /data0
6 R* [. a# m1 a1 k" }/dev/sdb1 133G 80G 47G 64% /data1
1 R- d W0 w1 g. n k/dev/sda6 7.8G 218M 7.2G 3% /var
' f _$ E" l2 U: d* \! {( P/dev/sda5 7.8G 166M 7.2G 3% /tmp
) J' l0 x& e3 ^( `8 h) q' R5 x/dev/sda3 9.7G 2.5G 6.8G 27% /usr. A9 O/ T% M! L, }1 U$ v, i
tmpfs 2.0G 0 2.0G 0% /dev/shm) s1 J6 i, e7 D8 S
+ K( K* _) j& F G9 T: `; d6 r1 A 参数 -h 表示使用「Human-readable」的输出,也就是在档案系统大小使用 GB、MB 等易读的格式。5 a" [% N6 o V# @/ {6 O& u% ?
" s3 [( f* O! V% @7 x3 `
上面的命令输出的第一个字段(Filesystem)及最后一个字段(Mounted on)分别是档案系统及其挂入点。我们可以看到 /dev/sda1 这个分割区被挂在根目录下。& K! @: e! M2 i5 \' U7 H! d
6 P8 M! _# S( V' H# e4 n 接下来的四个字段 Size、Used、Avail、及 Use% 分别是该分割区的容量、已使用的大小、剩下的大小、及使用的百分比。 FreeBSD下,当硬盘容量已满时,您可能会看到已使用的百分比超过 100%,因为 FreeBSD 会留一些空间给 root,让 root 在档案系统满时,还是可以写东西到该档案系统中,以进行管理。6 _; D) N; T: ^. {% n2 ^
1 ?% i0 \: _$ E3 D du:查询文件或文件夹的磁盘使用空间/ t& Q% U( M9 X7 `
$ k [! K1 I' |/ F9 b% h 如果当前目录下文件和文件夹很多,使用不带参数du的命令,可以循环列出所有文件和文件夹所使用的空间。这对查看究竟是那个地方过大是不利的,所以得指定深入目录的层数,参数:--max-depth=,这是个极为有用的参数!如下,注意使用“*”,可以得到文件的使用空间大小., f1 L3 H& k3 K1 n6 u+ K( l) N
0 J) M; u/ g; ? 提醒:一向命令比linux复杂的FreeBSD,它的du命令指定深入目录的层数却是比linux简化,为 -d。
2 f2 a# B- k% }. B- ?3 W. j1 Z$ w! Y% E3 B. ^" ]1 Q; d- D Z
以下是代码片段:& ?( N( J% r* D% I) C
- s, T( B" Y {
[root@bsso yayu]# du -h --max-depth=1 work/testing0 {- C$ `7 @ D2 o: o
27M work/testing/logs
+ ~- @6 T0 @( r- O8 j, ~$ S6 R35M work/testing/ O+ B' ]3 u( A- t9 }" E, i
. h3 `! `3 K7 P7 F
[root@bsso yayu]# du -h --max-depth=1 work/testing/*$ u: _, G& ~1 K% y3 [' N
8.0K work/testing/func.php
# N$ W. v$ u, z! A, K! O27M work/testing/logs
( v+ K3 x% j! {7 W" \1 O2 c8.1M work/testing/nohup.out9 d6 X5 F3 A9 g( [' I, p$ T* e
8.0K work/testing/testing_c.php+ _# J, X! s% a' F
12K work/testing/testing_func_reg.php
) c1 ~: o. N2 O. Y8.0K work/testing/testing_get.php: {9 T+ l; C* d- m: p
8.0K work/testing/testing_g.php5 H; B, f# {2 Y, ?
8.0K work/testing/var.php! E4 {8 w. K( w# I
1 ?0 P2 M: N5 n3 [. ?$ V
[root@bsso yayu]# du -h --max-depth=1 work/testing/logs/
( @$ j% ^. _, s; h) i! \27M work/testing/logs/
8 y, c. p) }; Y1 D) q! u# B. r/ h. |: q6 M
[root@bsso yayu]# du -h --max-depth=1 work/testing/logs/* n- o! T+ y! _& k, u* e
24K work/testing/logs/errdate.log_show.log: }9 T* m: Q* e
8.0K work/testing/logs/pertime_show.log
1 q3 @; l) l' c }$ y+ ~; ?27M work/testing/logs/show.log2 c* j* G% \# b2 J; D; U' J
% V4 M, [3 T' y# b* ^& n
|
|