|
|
当磁盘大小超过标准时会有报警提示,这时如果掌握df和du命令是非常明智的选择。1 h, G, r( _' W
; Q# `" W* D" b df可以查看一级文件夹大小、使用比例、档案系统及其挂入点,但对文件却无能为力。
% B# \# o& a, `% |3 ]$ r6 C du可以查看文件及文件夹的大小。: k2 _- D' u' j. H2 C0 l$ Y
) R1 V/ T/ O, y) c4 K, Y. e
两者配合使用,非常有效。比如用df查看哪个一级目录过大,然后用df查看文件夹或文件的大小,如此便可迅速确定症结。* U; M% O- R8 m" u8 ~" e5 h* \9 N6 V
, Q* @' c) y% c 下面分别简要介绍
4 f! X: E) m( |) n. E! p, c8 _7 S/ r3 m/ _0 F4 D, R% n7 f
df命令可以显示目前所有文件系统的可用空间及使用情形,请看下列这个例子:
7 h l* d9 l. G9 R8 e( {; v6 @( t; _; l0 J4 A
以下是代码片段:
5 u) V3 y% M. q0 G) L3 m- Z7 L' m1 M. B% X8 ]- Q3 ~% [4 v
[yayug@yayu ~]$ df -h+ B0 a! R) O2 W; i+ |
Filesystem Size Used Avail Use% Mounted on
0 E* r( k! s7 |; `; E7 W/dev/sda1 3.9G 300M 3.4G 8% /% S4 B1 H1 m" N
/dev/sda7 100G 188M 95G 1% /data0
5 T/ o: M. u" E1 _% T: V3 `0 b6 I/dev/sdb1 133G 80G 47G 64% /data1
% Q* d$ F7 J+ C+ ?8 P4 ]/dev/sda6 7.8G 218M 7.2G 3% /var
& C! L" ]8 k( y; R& b) _# U- O4 v/dev/sda5 7.8G 166M 7.2G 3% /tmp: u* h2 v. d" u! Y
/dev/sda3 9.7G 2.5G 6.8G 27% /usr
8 H, x3 i, \1 l9 k2 F- W9 Gtmpfs 2.0G 0 2.0G 0% /dev/shm' S6 F5 ~$ L7 Q0 j% R% B
$ X0 k) [3 _$ a: R* P+ Q+ P" e
参数 -h 表示使用「Human-readable」的输出,也就是在档案系统大小使用 GB、MB 等易读的格式。- x3 h% n: r+ L3 U) @- h) }% L8 t
+ w# s& p0 h( f" l/ @8 T# ]
上面的命令输出的第一个字段(Filesystem)及最后一个字段(Mounted on)分别是档案系统及其挂入点。我们可以看到 /dev/sda1 这个分割区被挂在根目录下。( j( T1 H. p; T4 U: P: i9 j
9 h6 U6 p) V) |% ^0 p
接下来的四个字段 Size、Used、Avail、及 Use% 分别是该分割区的容量、已使用的大小、剩下的大小、及使用的百分比。 FreeBSD下,当硬盘容量已满时,您可能会看到已使用的百分比超过 100%,因为 FreeBSD 会留一些空间给 root,让 root 在档案系统满时,还是可以写东西到该档案系统中,以进行管理。
7 j& ~' E" j: o$ _6 w+ Y* l F* ?+ z% b
du:查询文件或文件夹的磁盘使用空间
9 Z/ \" @ x2 \; ~5 N1 X1 }, v' p6 w& ?* o& ~/ D
如果当前目录下文件和文件夹很多,使用不带参数du的命令,可以循环列出所有文件和文件夹所使用的空间。这对查看究竟是那个地方过大是不利的,所以得指定深入目录的层数,参数:--max-depth=,这是个极为有用的参数!如下,注意使用“*”,可以得到文件的使用空间大小.& _% i- h) ^8 X3 C+ R$ [; Q& \* D: y
, r. B$ [: R5 J$ t* d 提醒:一向命令比linux复杂的FreeBSD,它的du命令指定深入目录的层数却是比linux简化,为 -d。0 J/ H9 l+ j5 F& U# L! T ], b
; b6 Z% L0 Y. K/ _8 M! }; k以下是代码片段:' _+ u' r- b# D9 m2 ]( m- p0 r
* V5 S; ~& D& k/ M# \: s
[root@bsso yayu]# du -h --max-depth=1 work/testing
0 R+ i- o- R) p: q% x8 Z27M work/testing/logs2 N7 `* T/ _( C" u9 X$ B0 J
35M work/testing
9 t$ y$ `; J* Z- G4 m
( A" c1 s4 {. G9 c& i5 r" w6 P8 B[root@bsso yayu]# du -h --max-depth=1 work/testing/*
% c% Y4 K7 m; D( R8.0K work/testing/func.php
; w9 u: h+ K0 o: W+ O& n27M work/testing/logs
+ ]2 H6 S) K- E7 U8.1M work/testing/nohup.out
# _' C2 Z4 i5 H3 J$ @- n8.0K work/testing/testing_c.php
0 G9 M6 {5 t" C8 f1 o2 [12K work/testing/testing_func_reg.php
" t( o$ z; @9 q+ w+ \, p8.0K work/testing/testing_get.php
8 }- X: G# b/ D8 @8.0K work/testing/testing_g.php `/ g9 o U: j9 G9 w' G+ w
8.0K work/testing/var.php; @% H9 ?# k+ C& F! l7 C' ^' z
# J2 r* \' t A1 L3 j2 W+ A+ i) F[root@bsso yayu]# du -h --max-depth=1 work/testing/logs/
! ?2 q- L! z) y( U7 A27M work/testing/logs/2 R: z3 M- T( Z& J! m8 _# i1 g0 @
, o' x4 t5 v* Q$ n7 v Q% h O) p[root@bsso yayu]# du -h --max-depth=1 work/testing/logs/*' v* g0 [5 ^! ~6 R
24K work/testing/logs/errdate.log_show.log+ l2 L6 L& y% s) M% P8 B& P
8.0K work/testing/logs/pertime_show.log$ `$ ~6 @, k8 F0 A
27M work/testing/logs/show.log2 H* P" }6 l% ~* L' D
* J# p1 J9 A- q- n* m; e |
|