|
当磁盘大小超过标准时会有报警提示,这时如果掌握df和du命令是非常明智的选择。
9 U9 b Q" ~3 x% J n
; i" d5 ^: ?6 O4 G7 c1 i8 | df可以查看一级文件夹大小、使用比例、档案系统及其挂入点,但对文件却无能为力。% b; b% U* [$ H/ K! W
du可以查看文件及文件夹的大小。9 a. p/ S& }. ^
, G$ {* b3 E( f9 b# E
两者配合使用,非常有效。比如用df查看哪个一级目录过大,然后用df查看文件夹或文件的大小,如此便可迅速确定症结。* Q% f- c( U2 \, z; R3 Q
" m: L( A' n; M1 V+ _( i
下面分别简要介绍
# R: I' A* x$ g2 G: |# i) K* [. P, a0 B* V5 H
df命令可以显示目前所有文件系统的可用空间及使用情形,请看下列这个例子:
/ Z0 K) ]# G. |" s) l9 B( \7 P4 s" _" C
以下是代码片段:
1 H1 @1 K2 g$ l' V
3 p W1 ^; h* W% w" F& |0 U[yayug@yayu ~]$ df -h
) y5 [- r5 n8 s1 k, mFilesystem Size Used Avail Use% Mounted on9 E1 S# ], [$ i/ ]5 V' K, h1 j7 s3 l
/dev/sda1 3.9G 300M 3.4G 8% /$ F5 }- V) R& g; V
/dev/sda7 100G 188M 95G 1% /data0
) s" P0 I) L0 I2 Q2 {/dev/sdb1 133G 80G 47G 64% /data1" p4 O1 W( U6 w: C5 ~( E
/dev/sda6 7.8G 218M 7.2G 3% /var
' J8 U4 s- \0 U ]+ M0 C, `/dev/sda5 7.8G 166M 7.2G 3% /tmp- l. X/ ]+ E: q
/dev/sda3 9.7G 2.5G 6.8G 27% /usr- n* w0 F. j. Y. F/ k- f% B A% \- u
tmpfs 2.0G 0 2.0G 0% /dev/shm& N# [! [ D+ p9 }* q' y
8 O" w# M5 @' X
参数 -h 表示使用「Human-readable」的输出,也就是在档案系统大小使用 GB、MB 等易读的格式。
: M# \& H% c5 q
6 J- y+ u F9 @( ~2 M 上面的命令输出的第一个字段(Filesystem)及最后一个字段(Mounted on)分别是档案系统及其挂入点。我们可以看到 /dev/sda1 这个分割区被挂在根目录下。% c+ d2 T- A3 }/ n9 e
" T/ o& r4 @4 \6 s! L* K, h 接下来的四个字段 Size、Used、Avail、及 Use% 分别是该分割区的容量、已使用的大小、剩下的大小、及使用的百分比。 FreeBSD下,当硬盘容量已满时,您可能会看到已使用的百分比超过 100%,因为 FreeBSD 会留一些空间给 root,让 root 在档案系统满时,还是可以写东西到该档案系统中,以进行管理。
9 C# A( b2 `7 T, z9 J
& [6 D; x W5 Q8 @" W6 K du:查询文件或文件夹的磁盘使用空间
7 o* |0 C9 i" l4 U
! K" e+ v" A# D 如果当前目录下文件和文件夹很多,使用不带参数du的命令,可以循环列出所有文件和文件夹所使用的空间。这对查看究竟是那个地方过大是不利的,所以得指定深入目录的层数,参数:--max-depth=,这是个极为有用的参数!如下,注意使用“*”,可以得到文件的使用空间大小.: _ t! `5 B [& {; g% Z' b0 ]
5 P+ m1 n0 t3 z T! J
提醒:一向命令比linux复杂的FreeBSD,它的du命令指定深入目录的层数却是比linux简化,为 -d。
( z. {; _! `' P/ D. g v/ p
5 O5 V7 b& h. x5 R以下是代码片段:+ @) R4 Y; e l
3 z+ [! |" M; M; N
[root@bsso yayu]# du -h --max-depth=1 work/testing
- m+ {; E* q- e% o27M work/testing/logs
! t* m+ } `7 K: L8 Y35M work/testing
3 u0 R; N A/ ^) Z5 O
' n% |- K! Q0 H6 }' w7 r[root@bsso yayu]# du -h --max-depth=1 work/testing/*
! L# {; D3 l5 `. i# N2 p8.0K work/testing/func.php* s2 @ }7 v: `* @
27M work/testing/logs" V: I% g0 Q8 ~0 f: P
8.1M work/testing/nohup.out5 M% ~! p6 _; i+ D' c$ e* E" V
8.0K work/testing/testing_c.php
, ]3 U' G. d$ S7 W. b( {+ U12K work/testing/testing_func_reg.php! A, q3 h. C H; A7 U
8.0K work/testing/testing_get.php1 g0 u; t9 s& j M
8.0K work/testing/testing_g.php) z0 S h/ Y8 f" l+ |, ~
8.0K work/testing/var.php3 i& C* N0 ^8 t
* F/ ^8 V8 L m" ?# Y( G3 `[root@bsso yayu]# du -h --max-depth=1 work/testing/logs/
3 Q: S' C. k2 o8 P' ^2 x27M work/testing/logs/
A% H: `: \4 r5 b9 K; s# d O% Q: u) V% q
[root@bsso yayu]# du -h --max-depth=1 work/testing/logs/*6 R9 k" i( u) M& u! M
24K work/testing/logs/errdate.log_show.log
/ h* _7 \1 R; a" }7 Q8.0K work/testing/logs/pertime_show.log0 W+ |8 h# e4 E. L9 K8 n
27M work/testing/logs/show.log5 ]$ d _$ u4 V# D7 G
+ [# p! n( |: h0 j2 t |
|