|
|
当磁盘大小超过标准时会有报警提示,这时如果掌握df和du命令是非常明智的选择。; e) m1 X2 T+ [7 E0 }
- A9 d, M! H: A4 V5 ]. P, x/ I df可以查看一级文件夹大小、使用比例、档案系统及其挂入点,但对文件却无能为力。# I2 G' \1 }' B' a5 n7 G {7 n
du可以查看文件及文件夹的大小。
3 Y- Q! P9 C/ |+ \% X$ M7 i- F6 n+ V2 N7 p! }9 t: l
两者配合使用,非常有效。比如用df查看哪个一级目录过大,然后用df查看文件夹或文件的大小,如此便可迅速确定症结。( u5 n5 P% o1 l+ ^
# |% k) ]. r! b# \% {' x2 Z 下面分别简要介绍
0 {% }' ^6 C; q! L3 ~- B
- T0 N, l- H+ F% w7 ] df命令可以显示目前所有文件系统的可用空间及使用情形,请看下列这个例子:7 G0 X0 j( \& T% { ~6 U
8 C9 s! Q' b) R1 P
以下是代码片段:
( Y; n, f+ U# _2 d" _$ Z& k* y) K
[yayug@yayu ~]$ df -h
$ e3 M+ q. f) B) JFilesystem Size Used Avail Use% Mounted on) Q5 j/ c( _; N1 X. D4 B/ B6 r! |
/dev/sda1 3.9G 300M 3.4G 8% /1 R5 A, I& W, g* K& F
/dev/sda7 100G 188M 95G 1% /data0; R$ A. D$ }1 I8 n
/dev/sdb1 133G 80G 47G 64% /data1: _. c. i0 W3 G! f5 c
/dev/sda6 7.8G 218M 7.2G 3% /var
+ Z, A- F1 F8 {6 _* j/ @0 D, L/dev/sda5 7.8G 166M 7.2G 3% /tmp
2 i m7 y- X" W- L/ V/dev/sda3 9.7G 2.5G 6.8G 27% /usr4 c5 J8 y& U' n- A; f+ _# p
tmpfs 2.0G 0 2.0G 0% /dev/shm5 _) A; w* |# y0 f
6 s8 V- n: n* u: j
参数 -h 表示使用「Human-readable」的输出,也就是在档案系统大小使用 GB、MB 等易读的格式。. I7 v! {' B. G2 W! f3 e
6 @# M4 k J0 h$ d8 W
上面的命令输出的第一个字段(Filesystem)及最后一个字段(Mounted on)分别是档案系统及其挂入点。我们可以看到 /dev/sda1 这个分割区被挂在根目录下。: S; h4 E8 G8 M2 P( _1 w
% W" N& N" I# _/ w
接下来的四个字段 Size、Used、Avail、及 Use% 分别是该分割区的容量、已使用的大小、剩下的大小、及使用的百分比。 FreeBSD下,当硬盘容量已满时,您可能会看到已使用的百分比超过 100%,因为 FreeBSD 会留一些空间给 root,让 root 在档案系统满时,还是可以写东西到该档案系统中,以进行管理。
, z* f, x" E6 ^1 _! K
' M/ P3 c f. M5 J( y I du:查询文件或文件夹的磁盘使用空间
- v: Q2 F" I n7 }$ c+ L" E+ F; W2 T6 c! l
如果当前目录下文件和文件夹很多,使用不带参数du的命令,可以循环列出所有文件和文件夹所使用的空间。这对查看究竟是那个地方过大是不利的,所以得指定深入目录的层数,参数:--max-depth=,这是个极为有用的参数!如下,注意使用“*”,可以得到文件的使用空间大小.
6 @$ f3 C% I/ o2 U t3 x3 i# M& _! c- m/ B# v: |. G
提醒:一向命令比linux复杂的FreeBSD,它的du命令指定深入目录的层数却是比linux简化,为 -d。3 i) z& h- K+ c8 M
( Z$ V" e. s9 S4 ^- P1 ~( _以下是代码片段:/ d2 f0 E# X0 ]" [3 r, r
! \3 a3 v, J, o[root@bsso yayu]# du -h --max-depth=1 work/testing5 |- G' |1 ?9 H$ k$ L, b- L
27M work/testing/logs
' a$ a8 J5 M; S& q0 c/ V+ Q35M work/testing
# u3 r6 c# U# u7 r- C0 U! e/ t4 ?) w4 U8 y4 a
[root@bsso yayu]# du -h --max-depth=1 work/testing/*% t7 X8 ]- l6 _4 A
8.0K work/testing/func.php8 [( r" V! q( P( d, }) a
27M work/testing/logs
% y, d( E+ E% N7 u d; Z3 K. D8.1M work/testing/nohup.out- a4 y: A8 P% V) c/ A2 a6 Z
8.0K work/testing/testing_c.php
I! j# G; z `$ S, h12K work/testing/testing_func_reg.php5 ?% Z6 E; h! k( f/ V8 {! d3 y) w+ W
8.0K work/testing/testing_get.php+ q$ K1 g) _& Y# F
8.0K work/testing/testing_g.php
- P8 r& i. G% ?# E7 M) ~8.0K work/testing/var.php
u5 T( }5 M5 ?( l+ V- ~$ s, h; Q: c# `3 T
[root@bsso yayu]# du -h --max-depth=1 work/testing/logs/) n: e8 I' h7 S/ L! g& i
27M work/testing/logs/6 i/ Z) N/ F! ]6 i
4 \* B0 E' O2 m. I$ [( P8 B2 h; {
[root@bsso yayu]# du -h --max-depth=1 work/testing/logs/*/ h: v# k1 i8 O0 P, w' c
24K work/testing/logs/errdate.log_show.log0 K U' R- A; \- U
8.0K work/testing/logs/pertime_show.log
6 V, Z5 Y, ^: ^' K3 {- \. ~' B U27M work/testing/logs/show.log- b) u: G& w& d8 ]. ^4 Z3 W8 l
) }( i& r% D+ A- Q |
|