|
|
当磁盘大小超过标准时会有报警提示,这时如果掌握df和du命令是非常明智的选择。: J0 s! |- |' {5 m
' [+ D) ]: r0 `' B K, c
df可以查看一级文件夹大小、使用比例、档案系统及其挂入点,但对文件却无能为力。/ }. f& i. |, t G) T% n8 p3 f
du可以查看文件及文件夹的大小。2 ~, K5 i* V# ~
+ ^& ]" b8 S, j* ]2 _0 w: ]3 S3 V
两者配合使用,非常有效。比如用df查看哪个一级目录过大,然后用df查看文件夹或文件的大小,如此便可迅速确定症结。5 F: a: {% m, P7 ^
4 ~2 n* p* c8 m" v6 \; L
下面分别简要介绍: y, ~- o: t, C3 ~+ z! Q$ r
& M% Y$ c5 t1 v2 L6 V% B& [ df命令可以显示目前所有文件系统的可用空间及使用情形,请看下列这个例子:5 C4 f' r3 a0 l7 ]9 M- D
5 t! e J3 s. w1 A以下是代码片段:
, q7 G! {6 C) \1 g' N9 Y* G: ^% A$ a& N) g) h- n7 W( @
[yayug@yayu ~]$ df -h2 g+ a! b. n( z# d) U: o
Filesystem Size Used Avail Use% Mounted on4 p3 D% p5 u; L! I7 W6 r! b. }
/dev/sda1 3.9G 300M 3.4G 8% /
+ C" i& i/ }0 |: K& \2 R/dev/sda7 100G 188M 95G 1% /data07 o" U! k3 _. m0 C& Z$ J c
/dev/sdb1 133G 80G 47G 64% /data1
$ b( x# D) |( w/dev/sda6 7.8G 218M 7.2G 3% /var6 K' t6 K/ ]6 S* F! L
/dev/sda5 7.8G 166M 7.2G 3% /tmp" F3 N) @. \% H# r
/dev/sda3 9.7G 2.5G 6.8G 27% /usr& h0 t& s7 [! v
tmpfs 2.0G 0 2.0G 0% /dev/shm% `0 u# X6 f$ v% v( }6 ]6 _
1 q! P( H( h$ A: ?* I4 \ 参数 -h 表示使用「Human-readable」的输出,也就是在档案系统大小使用 GB、MB 等易读的格式。
! ]" s1 e* r+ D* m% u r H) q8 P# h
0 L- E- e6 R% q( c$ z f 上面的命令输出的第一个字段(Filesystem)及最后一个字段(Mounted on)分别是档案系统及其挂入点。我们可以看到 /dev/sda1 这个分割区被挂在根目录下。4 k' \) d6 x. t# a: s' E4 g
: H0 Q7 b. \9 D) V$ K& p3 ?/ k, Q 接下来的四个字段 Size、Used、Avail、及 Use% 分别是该分割区的容量、已使用的大小、剩下的大小、及使用的百分比。 FreeBSD下,当硬盘容量已满时,您可能会看到已使用的百分比超过 100%,因为 FreeBSD 会留一些空间给 root,让 root 在档案系统满时,还是可以写东西到该档案系统中,以进行管理。
- _1 `% v Z4 Q0 Y& u
( O6 l' i, v; @ du:查询文件或文件夹的磁盘使用空间 p. e4 Z2 q5 W
/ n7 C( ]4 z T# z
如果当前目录下文件和文件夹很多,使用不带参数du的命令,可以循环列出所有文件和文件夹所使用的空间。这对查看究竟是那个地方过大是不利的,所以得指定深入目录的层数,参数:--max-depth=,这是个极为有用的参数!如下,注意使用“*”,可以得到文件的使用空间大小.
5 w# i, l0 R& z. N
# ~" ]2 M& E+ Q9 m/ d. _5 N% m- Q, a% B 提醒:一向命令比linux复杂的FreeBSD,它的du命令指定深入目录的层数却是比linux简化,为 -d。
$ }1 ]" O/ z! w- @' Y1 i3 c* t' l. p- G7 k! o- x/ C! S3 n
以下是代码片段:1 c3 ~. F% j+ a: D C5 a* |+ H
3 H5 V! `9 H7 C! i% K
[root@bsso yayu]# du -h --max-depth=1 work/testing$ P' L, N! ~8 E; [
27M work/testing/logs5 i$ C+ n5 d7 y. o$ d
35M work/testing2 r3 ~: e) z" k+ W, H" T, i
9 w/ B4 X3 y3 Z' w- p% q6 x, ^5 ~[root@bsso yayu]# du -h --max-depth=1 work/testing/*
% t$ a* e# K% q6 K Z7 C# f8.0K work/testing/func.php. n% U _, }7 l0 y
27M work/testing/logs. n' t" w/ w9 ?* X
8.1M work/testing/nohup.out; a a) I2 q7 B/ j# Y
8.0K work/testing/testing_c.php# b2 h. R/ i. T: J
12K work/testing/testing_func_reg.php
( x* t+ J2 t. q/ Y8.0K work/testing/testing_get.php
! O0 t2 W2 M* b4 p8.0K work/testing/testing_g.php: p/ |& _6 I% c$ V% i$ L
8.0K work/testing/var.php
/ B7 N; }9 D; q
1 a* |4 h2 F% B. Y1 A5 C( N* g6 P1 x[root@bsso yayu]# du -h --max-depth=1 work/testing/logs/; B8 z' Y3 m6 L& t
27M work/testing/logs/# E6 H8 _# k" J' H! u$ `) S
. T$ Y; u) a( l7 z
[root@bsso yayu]# du -h --max-depth=1 work/testing/logs/*
+ p4 l: ]6 {0 o1 S# y& {24K work/testing/logs/errdate.log_show.log
# m: |& R0 K- N8.0K work/testing/logs/pertime_show.log5 n V1 E. Q: g3 M& j. @
27M work/testing/logs/show.log
, H( w0 E! ? x$ s3 S' @% Y8 c" F9 E8 W2 n% V9 q& T# }
|
|