|
当磁盘大小超过标准时会有报警提示,这时如果掌握df和du命令是非常明智的选择。' T1 t2 g1 a1 D) ~: S# X
# M. v# ^. n6 n( E/ q
df可以查看一级文件夹大小、使用比例、档案系统及其挂入点,但对文件却无能为力。
4 n$ R" i& g5 }; y/ k: J du可以查看文件及文件夹的大小。
/ f% L% ^. u5 r; G6 Z/ D3 a0 g! L/ f% g- q
两者配合使用,非常有效。比如用df查看哪个一级目录过大,然后用df查看文件夹或文件的大小,如此便可迅速确定症结。# i9 s5 }7 A7 y. ~
" K- G& Q. a" H h 下面分别简要介绍- |9 F9 C; K0 N# Y
0 a. T- U% R9 T! A; C/ g, J
df命令可以显示目前所有文件系统的可用空间及使用情形,请看下列这个例子:
; a0 v X+ B+ T3 g/ E' x9 Z. C
9 m* s7 V) q1 G/ W% S以下是代码片段:
1 f9 P8 t p4 ~! F8 a7 `8 Z
' G! m0 a( M4 E" ]; c[yayug@yayu ~]$ df -h
, O% j& N/ p V% d+ \* C4 A- eFilesystem Size Used Avail Use% Mounted on
" Y0 }4 K. q/ R: i, h% q; E- o/dev/sda1 3.9G 300M 3.4G 8% /- h6 I/ K; K9 ~% t
/dev/sda7 100G 188M 95G 1% /data01 ?! W1 z3 p/ J
/dev/sdb1 133G 80G 47G 64% /data1
2 x' [3 t8 o& y. p9 P! M) o% c/dev/sda6 7.8G 218M 7.2G 3% /var B5 x5 o# o7 B
/dev/sda5 7.8G 166M 7.2G 3% /tmp. r, A2 S) J' p' }9 w O7 x; a
/dev/sda3 9.7G 2.5G 6.8G 27% /usr
$ u0 `: i) g V; e& g* htmpfs 2.0G 0 2.0G 0% /dev/shm) W x+ ~# ~9 s/ P* Q% R% ~
5 F7 ` p7 M' L% N! G( [# j: E9 R! }& l 参数 -h 表示使用「Human-readable」的输出,也就是在档案系统大小使用 GB、MB 等易读的格式。; b2 U A F1 G! Y. S5 Z! @" V
7 Z7 B3 t+ |1 N7 f( u 上面的命令输出的第一个字段(Filesystem)及最后一个字段(Mounted on)分别是档案系统及其挂入点。我们可以看到 /dev/sda1 这个分割区被挂在根目录下。! b0 `0 I; ^) y/ p$ P# U/ u6 L
" D' q. n8 o) p2 n7 p- e' m& z& w 接下来的四个字段 Size、Used、Avail、及 Use% 分别是该分割区的容量、已使用的大小、剩下的大小、及使用的百分比。 FreeBSD下,当硬盘容量已满时,您可能会看到已使用的百分比超过 100%,因为 FreeBSD 会留一些空间给 root,让 root 在档案系统满时,还是可以写东西到该档案系统中,以进行管理。
, Z+ {5 D: ]) P
- ], h1 r7 i9 _* ]# M du:查询文件或文件夹的磁盘使用空间# Z) x5 e( M5 }4 s
2 g) e6 L: }+ W3 v8 p
如果当前目录下文件和文件夹很多,使用不带参数du的命令,可以循环列出所有文件和文件夹所使用的空间。这对查看究竟是那个地方过大是不利的,所以得指定深入目录的层数,参数:--max-depth=,这是个极为有用的参数!如下,注意使用“*”,可以得到文件的使用空间大小.
- X, L6 w6 R- @$ e1 y& c6 e0 B6 y9 O+ w6 _5 a8 I
提醒:一向命令比linux复杂的FreeBSD,它的du命令指定深入目录的层数却是比linux简化,为 -d。
! ?- a" v$ i! U# T M1 I1 [ v7 G9 w0 i& ]- `1 B0 S7 D
以下是代码片段:2 k. h7 h% D+ z0 x/ ~
% P9 ]0 }7 Z, f# N
[root@bsso yayu]# du -h --max-depth=1 work/testing4 F7 l/ e( ]( U; h
27M work/testing/logs
6 h H$ H7 W2 x0 c5 \# `: N) `# a6 Y, x35M work/testing
0 S* {" m" D8 U5 c# Q# f% l0 N9 |" ^, `7 k
[root@bsso yayu]# du -h --max-depth=1 work/testing/*5 |7 e! U" X! a$ b- H
8.0K work/testing/func.php; {7 |" H9 T8 ^
27M work/testing/logs
& T0 z; h/ x' S8.1M work/testing/nohup.out0 [$ g) @2 X3 _- j- o
8.0K work/testing/testing_c.php
* \9 m; O! ^: k; u& N# V- _+ y: ^12K work/testing/testing_func_reg.php
* g+ Z$ o Q- W8.0K work/testing/testing_get.php
3 V8 C9 g% T# I+ y. A4 H6 J8.0K work/testing/testing_g.php, }* V# `4 T, q1 h; O$ Z4 @+ ^
8.0K work/testing/var.php
. a& Q# M: o8 A- n2 s8 c! r! A9 B' r
[root@bsso yayu]# du -h --max-depth=1 work/testing/logs/
) r) c. P0 y0 ?% Y6 |! x27M work/testing/logs/
7 X1 M( N" m M4 g4 }: z5 \: ?: E* I% N' p9 N3 H
[root@bsso yayu]# du -h --max-depth=1 work/testing/logs/*
- ^( b5 h1 j" \+ T" k I* H24K work/testing/logs/errdate.log_show.log2 P! @# `9 `2 k
8.0K work/testing/logs/pertime_show.log
& S4 T0 v$ U9 s1 U# `: ^! @27M work/testing/logs/show.log
, y- m, d- c: c: R0 l5 B. o# r
3 y* o: `& @7 g! n |
|