|
|
当磁盘大小超过标准时会有报警提示,这时如果掌握df和du命令是非常明智的选择。
4 h6 n" p3 m4 f5 Z6 d% D
5 N" E0 f6 P3 w6 A df可以查看一级文件夹大小、使用比例、档案系统及其挂入点,但对文件却无能为力。- H( u' G8 ]+ w5 `) L" l9 {: t( ?1 p
du可以查看文件及文件夹的大小。& S q% h, i) |9 {6 u4 Z# A3 G) H
# W! W) {/ N# e2 c1 S l* i 两者配合使用,非常有效。比如用df查看哪个一级目录过大,然后用df查看文件夹或文件的大小,如此便可迅速确定症结。$ V3 ~, {1 x- t- Q
C4 e! x5 o, g7 P: ? j
下面分别简要介绍
9 z2 H q" h" m- U" j' I7 X
3 G) t) h5 Z* a1 b; B5 y df命令可以显示目前所有文件系统的可用空间及使用情形,请看下列这个例子:% ^1 [! T4 t! V
% R _# A5 F& a; i" ~以下是代码片段:
7 t z. M& h5 y' p. c- k7 ~, A' p7 [7 G; V- ^! l0 U
[yayug@yayu ~]$ df -h
# R1 k, {2 r! K4 `% FFilesystem Size Used Avail Use% Mounted on
2 J$ Y, A1 S9 \# D3 S, X, ]0 H' k/dev/sda1 3.9G 300M 3.4G 8% /7 ^+ T# _. D5 ]+ _& J- F# P
/dev/sda7 100G 188M 95G 1% /data0
1 ^3 E7 c/ y, B/ v% b, x: T/dev/sdb1 133G 80G 47G 64% /data1
. u0 D2 @/ N1 X! `/dev/sda6 7.8G 218M 7.2G 3% /var
# n' l m- h' h8 a# V* x/dev/sda5 7.8G 166M 7.2G 3% /tmp
9 Y% g* a! W. g9 z/dev/sda3 9.7G 2.5G 6.8G 27% /usr
. B4 e" x7 ]/ \tmpfs 2.0G 0 2.0G 0% /dev/shm( K0 W) G5 w. A3 z w
2 p6 G3 ]9 c* L5 f8 u/ a 参数 -h 表示使用「Human-readable」的输出,也就是在档案系统大小使用 GB、MB 等易读的格式。2 S- \0 a+ ]5 Q# B3 {+ c
) x' \& @& `( D
上面的命令输出的第一个字段(Filesystem)及最后一个字段(Mounted on)分别是档案系统及其挂入点。我们可以看到 /dev/sda1 这个分割区被挂在根目录下。
6 L( D3 _& x/ R) v' D
, c, t1 J8 r& z3 [( N# J$ q2 ~# t7 u 接下来的四个字段 Size、Used、Avail、及 Use% 分别是该分割区的容量、已使用的大小、剩下的大小、及使用的百分比。 FreeBSD下,当硬盘容量已满时,您可能会看到已使用的百分比超过 100%,因为 FreeBSD 会留一些空间给 root,让 root 在档案系统满时,还是可以写东西到该档案系统中,以进行管理。: d4 h0 a: E- s& v# o- G- ?
+ L# o7 f/ O( g' L' V
du:查询文件或文件夹的磁盘使用空间1 F3 E5 `. k3 L+ M
$ C' Z2 Y! E" d 如果当前目录下文件和文件夹很多,使用不带参数du的命令,可以循环列出所有文件和文件夹所使用的空间。这对查看究竟是那个地方过大是不利的,所以得指定深入目录的层数,参数:--max-depth=,这是个极为有用的参数!如下,注意使用“*”,可以得到文件的使用空间大小.8 l; u* l( l; r V; g
7 ?: d1 n- y( G E/ o! B) O 提醒:一向命令比linux复杂的FreeBSD,它的du命令指定深入目录的层数却是比linux简化,为 -d。7 k$ `+ E7 o8 A6 p, v
2 v! Q6 K0 j8 }3 ~! D
以下是代码片段:7 H6 u8 \, K/ B* n+ k3 I
. E7 ~" \+ ~. O( u) Q |2 d; u0 P
[root@bsso yayu]# du -h --max-depth=1 work/testing
' B& ^" E/ w. P: ]# ?. T# H27M work/testing/logs& K! b8 H: d$ {& e5 H
35M work/testing# b$ ~! [/ Y' e1 t7 R
2 P A- E% J# e
[root@bsso yayu]# du -h --max-depth=1 work/testing/*# C; _6 F9 K7 t) y* D* x
8.0K work/testing/func.php8 [6 j2 O! W, }! m- t
27M work/testing/logs
2 o6 H. @1 r/ g- v6 G8.1M work/testing/nohup.out
# M1 ~9 ^# N9 x8 T" f) i8.0K work/testing/testing_c.php& t4 U8 i1 f: c$ s! M! k1 t2 ~, B) q
12K work/testing/testing_func_reg.php/ W! S( \9 u4 C
8.0K work/testing/testing_get.php/ Q5 O+ `7 @4 u" e. \. D
8.0K work/testing/testing_g.php8 z; F8 L# u3 m% c4 W
8.0K work/testing/var.php' f' v! R7 F( z, Z# ? k/ ]
# t( `# q8 B$ {% o3 x7 _[root@bsso yayu]# du -h --max-depth=1 work/testing/logs/
/ z8 n6 ^. Y3 U- @27M work/testing/logs/
5 w* I) j4 W" c/ u. ~- q3 [
g+ E1 l" t' ~4 {# O4 D[root@bsso yayu]# du -h --max-depth=1 work/testing/logs/*
4 w7 u3 j+ s. V9 O6 \8 A24K work/testing/logs/errdate.log_show.log
1 p* g5 l f) h3 p% f2 @2 x3 P& `8.0K work/testing/logs/pertime_show.log/ T9 j8 E u H& A3 Q: o) n1 S
27M work/testing/logs/show.log+ N) y# _ Z2 J; g8 i# Y& }& A N
/ W9 Y* T: F L; P8 n: s
|
|