|
|
当磁盘大小超过标准时会有报警提示,这时如果掌握df和du命令是非常明智的选择。
0 t; y& b: X) j/ C! |- M0 b2 z
/ a7 M3 W2 l" D1 h df可以查看一级文件夹大小、使用比例、档案系统及其挂入点,但对文件却无能为力。
: a( G G: }6 c2 O3 Z4 Y du可以查看文件及文件夹的大小。
. L1 n9 j8 J$ f+ q9 q* @* J
' h0 c# i7 P' A- }$ Y/ M 两者配合使用,非常有效。比如用df查看哪个一级目录过大,然后用df查看文件夹或文件的大小,如此便可迅速确定症结。" J2 C6 z+ ~5 v/ f; R7 s* n
5 s! o: Q8 R8 K% i 下面分别简要介绍* C. Z- k ], L7 y. L: C
: r5 u1 c/ Q( e
df命令可以显示目前所有文件系统的可用空间及使用情形,请看下列这个例子:
u1 D: N- c: Y. d1 `# r& o ?
) m, T) ~ p0 J8 e. `以下是代码片段:& j$ L" s0 ]' Y v. ~! W" f
, k3 Q& }" [6 X! I
[yayug@yayu ~]$ df -h
/ D# e4 u! D2 A1 a& sFilesystem Size Used Avail Use% Mounted on3 J% ?- ?& m5 P9 S+ c6 ^
/dev/sda1 3.9G 300M 3.4G 8% /. c: C# _: q6 Z: Y' A" r5 {
/dev/sda7 100G 188M 95G 1% /data0
6 y& K0 I b- [( i/dev/sdb1 133G 80G 47G 64% /data1: U; N/ a3 ~5 k0 ?' s8 g7 I
/dev/sda6 7.8G 218M 7.2G 3% /var
7 \$ a7 n: Y* W! P8 @5 N9 b/dev/sda5 7.8G 166M 7.2G 3% /tmp9 S+ M7 J& F& ?& K, D+ O3 H" s- j
/dev/sda3 9.7G 2.5G 6.8G 27% /usr. `5 N/ q8 ~7 t2 V* o, M
tmpfs 2.0G 0 2.0G 0% /dev/shm) z) }; z1 |, S) f8 v7 G
2 @* x% L7 M+ e# D2 j, A, Z d
参数 -h 表示使用「Human-readable」的输出,也就是在档案系统大小使用 GB、MB 等易读的格式。
. x& |5 ~7 D5 c+ d0 c7 W: t) H: |, ]/ ]' g& @: |* Q1 k' m
上面的命令输出的第一个字段(Filesystem)及最后一个字段(Mounted on)分别是档案系统及其挂入点。我们可以看到 /dev/sda1 这个分割区被挂在根目录下。: x6 }% }" A9 x' R1 ~) _% k
1 U2 r9 q2 D/ O2 a" L) e' Z0 P( y* X. H
接下来的四个字段 Size、Used、Avail、及 Use% 分别是该分割区的容量、已使用的大小、剩下的大小、及使用的百分比。 FreeBSD下,当硬盘容量已满时,您可能会看到已使用的百分比超过 100%,因为 FreeBSD 会留一些空间给 root,让 root 在档案系统满时,还是可以写东西到该档案系统中,以进行管理。
% A( F5 g; X$ C2 l* ^! z
: B, c' ~2 K) q2 s du:查询文件或文件夹的磁盘使用空间
! M8 Q" N/ c0 J' T( F3 e
( D1 {0 `) I* N2 ?) s' Y6 Z 如果当前目录下文件和文件夹很多,使用不带参数du的命令,可以循环列出所有文件和文件夹所使用的空间。这对查看究竟是那个地方过大是不利的,所以得指定深入目录的层数,参数:--max-depth=,这是个极为有用的参数!如下,注意使用“*”,可以得到文件的使用空间大小.
" z7 m" @9 T3 ^7 n! c0 ~
( y: k! T+ K q* j 提醒:一向命令比linux复杂的FreeBSD,它的du命令指定深入目录的层数却是比linux简化,为 -d。8 {( `8 Z/ c5 N+ h( [
. Z1 u/ o* g i9 F B以下是代码片段:0 u* e; G" U3 t. |6 L0 W8 X# ^
0 W. F; {2 [8 h+ x) B* j- c
[root@bsso yayu]# du -h --max-depth=1 work/testing
/ H' d, t3 k7 X' ~27M work/testing/logs
+ N5 F. c; U0 r35M work/testing
5 M; d- F" q; S. I4 X' S8 {, Q7 m3 l5 v! Q
[root@bsso yayu]# du -h --max-depth=1 work/testing/*/ f) ?6 l/ }$ S, h9 P" `$ X h
8.0K work/testing/func.php; r) i3 W# N4 g9 K8 z
27M work/testing/logs
- z& J+ t. u+ E4 Z. B8.1M work/testing/nohup.out2 J# z$ j6 M& ?$ P, k3 w2 p
8.0K work/testing/testing_c.php
- ]" T0 |) X ?( M12K work/testing/testing_func_reg.php
k2 V; J8 o& ]* w* q5 p8.0K work/testing/testing_get.php$ B0 P7 l, G" I3 Z# f
8.0K work/testing/testing_g.php
1 Q& v3 B2 W' n8.0K work/testing/var.php
1 q* ~7 Y* G: J7 t3 k6 g8 s7 M
% Z8 [8 W) W: J9 G8 ][root@bsso yayu]# du -h --max-depth=1 work/testing/logs/
" d5 j; G3 t9 I5 Z27M work/testing/logs/0 w* [3 J* B. x
7 [7 M V; n+ k- i
[root@bsso yayu]# du -h --max-depth=1 work/testing/logs/*" |+ o; A/ ^5 b( [1 E% \5 Y8 K
24K work/testing/logs/errdate.log_show.log
# L* R7 |5 H8 k% M: D5 w$ D8.0K work/testing/logs/pertime_show.log- M# `" S% X: h6 J! d
27M work/testing/logs/show.log
* Q$ }4 s. a' B* M& u3 B- t! O+ [4 N: ]% G" y6 f2 F% x
|
|