|
|
当磁盘大小超过标准时会有报警提示,这时如果掌握df和du命令是非常明智的选择。) o7 V' C& K( `+ A% I. y" Q
f3 @! F$ g: l1 z. P+ V df可以查看一级文件夹大小、使用比例、档案系统及其挂入点,但对文件却无能为力。$ S1 J% b* i: G1 m [& L* P
du可以查看文件及文件夹的大小。
/ G& Q& ]1 L6 @# Q3 r7 m9 u. `
' z3 H/ ]$ |% Z3 w: I1 r, R0 E 两者配合使用,非常有效。比如用df查看哪个一级目录过大,然后用df查看文件夹或文件的大小,如此便可迅速确定症结。
; H' k* d0 C/ G) R6 w/ x o: [7 D3 T( H
下面分别简要介绍% |8 |, ]+ w& X# K ^- j1 L
3 a; ^" K+ v7 j S& R# T5 K2 X; T df命令可以显示目前所有文件系统的可用空间及使用情形,请看下列这个例子:
9 u- w" Z, I* p& [, B# L' a$ w; _* P( }) ]
以下是代码片段:/ N9 ?1 g6 T4 S' M0 c4 d+ v: f- ?5 L
) A7 D3 n/ w* s' r; K, I[yayug@yayu ~]$ df -h
* J3 ] L/ _" n0 oFilesystem Size Used Avail Use% Mounted on" `1 ^, b j* y1 ]
/dev/sda1 3.9G 300M 3.4G 8% /
3 a" |$ x8 C8 ~( l2 b0 H/dev/sda7 100G 188M 95G 1% /data0
8 N- b4 H% c4 m/dev/sdb1 133G 80G 47G 64% /data1
/ r; J/ [, U# r3 Q ^ h$ s4 o/dev/sda6 7.8G 218M 7.2G 3% /var9 z2 \1 M. e7 p+ I9 s- x
/dev/sda5 7.8G 166M 7.2G 3% /tmp
+ b& _* q$ Z! e$ ?; c/dev/sda3 9.7G 2.5G 6.8G 27% /usr
) G# P7 [3 O# w. A3 }* J5 htmpfs 2.0G 0 2.0G 0% /dev/shm8 \. C% @4 i! s \
5 U' W% w3 T2 t 参数 -h 表示使用「Human-readable」的输出,也就是在档案系统大小使用 GB、MB 等易读的格式。
/ t' j/ a3 t" \- s. y. p4 E
. _: g, _3 G9 v; E1 e 上面的命令输出的第一个字段(Filesystem)及最后一个字段(Mounted on)分别是档案系统及其挂入点。我们可以看到 /dev/sda1 这个分割区被挂在根目录下。
4 @1 z" Q5 b. i% A1 r0 W5 F e1 A
接下来的四个字段 Size、Used、Avail、及 Use% 分别是该分割区的容量、已使用的大小、剩下的大小、及使用的百分比。 FreeBSD下,当硬盘容量已满时,您可能会看到已使用的百分比超过 100%,因为 FreeBSD 会留一些空间给 root,让 root 在档案系统满时,还是可以写东西到该档案系统中,以进行管理。7 \" D1 k) z2 v- }' o
/ H; q, p, b4 ? du:查询文件或文件夹的磁盘使用空间3 N/ Y, o7 ]" ~
% |! V. k/ P$ O2 i 如果当前目录下文件和文件夹很多,使用不带参数du的命令,可以循环列出所有文件和文件夹所使用的空间。这对查看究竟是那个地方过大是不利的,所以得指定深入目录的层数,参数:--max-depth=,这是个极为有用的参数!如下,注意使用“*”,可以得到文件的使用空间大小.$ L/ |, Q# X& T
4 z. }6 ? W. i9 T5 c. [ 提醒:一向命令比linux复杂的FreeBSD,它的du命令指定深入目录的层数却是比linux简化,为 -d。$ Q! ^+ V# j6 }# }2 @
- Q2 ^: o8 |, K8 r5 f以下是代码片段:
% C d& \ D X) K) x
8 f. G+ q7 ]! Q) `. O[root@bsso yayu]# du -h --max-depth=1 work/testing' C% K% N" |4 a" _
27M work/testing/logs/ k$ Y, _ K' o& y4 d
35M work/testing( E" f# @# V3 N4 s1 u" O5 {5 s
6 @* P2 h) r- Y* p: w2 `[root@bsso yayu]# du -h --max-depth=1 work/testing/* ~! P: j, h& I, C' L
8.0K work/testing/func.php
# O. m1 E8 q/ D9 O/ D& B' g27M work/testing/logs
`$ [: z8 L, Y3 l8.1M work/testing/nohup.out( T; y+ o) V; b; C
8.0K work/testing/testing_c.php
: ~" O1 C! p' F* j12K work/testing/testing_func_reg.php
& ^2 ]2 _' ]9 x8.0K work/testing/testing_get.php0 F2 f, F0 O: d! _9 i7 @
8.0K work/testing/testing_g.php
# J/ J" n1 O1 H. `. B& g$ O8.0K work/testing/var.php
, B; K1 ]$ K! }9 F; Q8 `+ x( T6 ^! L6 o
[root@bsso yayu]# du -h --max-depth=1 work/testing/logs/, U$ f! A6 H4 j# e0 ]
27M work/testing/logs/( T. Z+ T, U& Z2 t
( c, _" B# k7 g. `2 i[root@bsso yayu]# du -h --max-depth=1 work/testing/logs/*
0 [* X7 b- T. W! h7 A4 W' y24K work/testing/logs/errdate.log_show.log
4 C: L% \( Z4 l1 y8.0K work/testing/logs/pertime_show.log3 \. J. y8 t& ^( ^
27M work/testing/logs/show.log. ?3 \6 G) _- m) d6 `7 W
7 w/ }% Q( C! p+ t
|
|