|
当磁盘大小超过标准时会有报警提示,这时如果掌握df和du命令是非常明智的选择。! P7 h8 q& u5 |; b& Z9 o3 X+ |
1 U0 D% P9 j( \) T/ U
df可以查看一级文件夹大小、使用比例、档案系统及其挂入点,但对文件却无能为力。+ ?- b- t1 z6 l9 ^+ w( P
du可以查看文件及文件夹的大小。
6 D9 C4 T4 i& j( }+ u& V& q
( n" S# l2 M& Z4 n v& {9 `& ^ 两者配合使用,非常有效。比如用df查看哪个一级目录过大,然后用df查看文件夹或文件的大小,如此便可迅速确定症结。9 \( T; B2 w) g$ E
" N! G! [" x, l- E6 Z; ~* }$ @
下面分别简要介绍' i ~# `4 Q1 Z! Z# @# J
! |7 d3 M5 r2 \ n3 X& z- }" S
df命令可以显示目前所有文件系统的可用空间及使用情形,请看下列这个例子:
/ k6 |# z' l* r5 g1 b! J7 K
" }3 r2 R% Z' Z! @以下是代码片段:
5 h, c# @* D) Z
( n5 z) Z; ]' s. x! p, W7 D[yayug@yayu ~]$ df -h7 b6 h4 q$ S& r, `) p3 q9 W% b$ C+ c
Filesystem Size Used Avail Use% Mounted on
5 H! L+ x3 @* E8 b9 F+ X/dev/sda1 3.9G 300M 3.4G 8% /% d" s4 c' E7 S6 w4 k5 T& I- T
/dev/sda7 100G 188M 95G 1% /data0+ j5 {4 x, q. u$ P5 E+ Z& W
/dev/sdb1 133G 80G 47G 64% /data1: c$ j/ H: c$ i' a7 |) s( d5 y
/dev/sda6 7.8G 218M 7.2G 3% /var
" l4 V& Q4 s" X! q' N: N: b+ u/dev/sda5 7.8G 166M 7.2G 3% /tmp, Q9 m& O! ]- f! D
/dev/sda3 9.7G 2.5G 6.8G 27% /usr
# A3 p- h. k; ^1 R7 ctmpfs 2.0G 0 2.0G 0% /dev/shm: g0 K2 ~7 m/ k1 U
& e: q5 G& {6 `; T5 c1 f* A
参数 -h 表示使用「Human-readable」的输出,也就是在档案系统大小使用 GB、MB 等易读的格式。6 X p" b2 b+ Y0 s( ]- H
! b9 C" ?9 X0 n
上面的命令输出的第一个字段(Filesystem)及最后一个字段(Mounted on)分别是档案系统及其挂入点。我们可以看到 /dev/sda1 这个分割区被挂在根目录下。
; B: l5 }% @. K
, X. f: h+ |7 l3 N9 Z 接下来的四个字段 Size、Used、Avail、及 Use% 分别是该分割区的容量、已使用的大小、剩下的大小、及使用的百分比。 FreeBSD下,当硬盘容量已满时,您可能会看到已使用的百分比超过 100%,因为 FreeBSD 会留一些空间给 root,让 root 在档案系统满时,还是可以写东西到该档案系统中,以进行管理。
: B' T/ H a& x9 Q. U6 M
4 L8 u( g' X P+ G du:查询文件或文件夹的磁盘使用空间7 I9 o* B0 p3 J% U
' c% Z7 Y+ P+ f# m! U5 l5 I
如果当前目录下文件和文件夹很多,使用不带参数du的命令,可以循环列出所有文件和文件夹所使用的空间。这对查看究竟是那个地方过大是不利的,所以得指定深入目录的层数,参数:--max-depth=,这是个极为有用的参数!如下,注意使用“*”,可以得到文件的使用空间大小.7 @2 q" f/ B* \1 }
8 _2 d& b. h* G$ V7 J, X! x$ l" u. Z 提醒:一向命令比linux复杂的FreeBSD,它的du命令指定深入目录的层数却是比linux简化,为 -d。
8 v+ }( `- }8 a2 Z' n2 F* z
! J: Y7 L9 L5 S; ~% e以下是代码片段:2 ]9 H. s9 @; E R* s
: {% W3 u3 h% Z3 z
[root@bsso yayu]# du -h --max-depth=1 work/testing
/ v! r0 ^2 D" R9 d1 ?27M work/testing/logs% Q0 c# X6 B$ {( Z
35M work/testing$ @# y; {" g& a! ~/ O8 l# m
8 D g0 [4 k5 N$ J1 P/ v+ ]/ k% D
[root@bsso yayu]# du -h --max-depth=1 work/testing/*' j0 L' H* ]* Z& H0 l+ V
8.0K work/testing/func.php
& i0 v6 u3 h( Y# t, C2 X0 H27M work/testing/logs
4 d) `# c+ U4 M8.1M work/testing/nohup.out Q! g* V, u6 l, N) `; F
8.0K work/testing/testing_c.php0 L+ z) ]% e3 h
12K work/testing/testing_func_reg.php, V: P5 ?; u$ w& ~
8.0K work/testing/testing_get.php9 n( \6 a- ?1 U3 M2 e; w3 h
8.0K work/testing/testing_g.php
6 c6 t& M# R- ~/ w) i2 x- Z8.0K work/testing/var.php
2 t. d, u% y$ p$ V2 T/ S0 v
* K9 F" V8 r0 z4 _( O5 \[root@bsso yayu]# du -h --max-depth=1 work/testing/logs/6 L0 D% y/ I3 Z+ g2 \6 h
27M work/testing/logs/
! Y- j' Y+ [3 ^$ U, {
. G( A" W2 [2 k( T0 R[root@bsso yayu]# du -h --max-depth=1 work/testing/logs/*
, W0 ]' k/ N$ w. M$ ]" X+ d- K24K work/testing/logs/errdate.log_show.log( v) L$ d9 B- g# I
8.0K work/testing/logs/pertime_show.log- j$ v4 \* E- l0 l4 Z8 |
27M work/testing/logs/show.log& l2 F( H3 p1 R4 q1 c# z2 l3 K
( g# P# | z. d# t$ g: G |
|