|
当磁盘大小超过标准时会有报警提示,这时如果掌握df和du命令是非常明智的选择。7 Z3 b, W# o, d ` F8 E3 ?
( l6 p- g, b. |6 ], r% b- q; z df可以查看一级文件夹大小、使用比例、档案系统及其挂入点,但对文件却无能为力。5 O' d# {: t4 F0 n! Z8 U5 e
du可以查看文件及文件夹的大小。
! R6 V9 |7 {- c: M/ t3 v$ |
, ]/ D4 X; B9 o* b3 r( X 两者配合使用,非常有效。比如用df查看哪个一级目录过大,然后用df查看文件夹或文件的大小,如此便可迅速确定症结。4 A5 X$ S4 K3 ?
% U1 ]6 {! v/ S' U
下面分别简要介绍& S& z) V2 u4 b+ X( W& H5 n2 g A
) g& E& w' s4 O: f% h
df命令可以显示目前所有文件系统的可用空间及使用情形,请看下列这个例子:
' g' L, |; O$ a( d& [* g4 E
9 \% q- w' M0 w/ L* _2 U; J" u以下是代码片段:' t7 l1 U/ S0 X1 G+ h% z: R9 o
2 ]0 d; J; X: v3 S0 A0 l9 H
[yayug@yayu ~]$ df -h
! R$ h5 J0 y2 o/ o F* t OFilesystem Size Used Avail Use% Mounted on( p. j2 ^6 t8 s
/dev/sda1 3.9G 300M 3.4G 8% /
) z* [" _5 ~, Y( [6 U/dev/sda7 100G 188M 95G 1% /data0$ T: m- C5 i0 B$ {
/dev/sdb1 133G 80G 47G 64% /data1
K) q9 [7 [- Z$ U' o* W; ?4 Y/ P/dev/sda6 7.8G 218M 7.2G 3% /var
( b% W0 R2 F1 B T# `/dev/sda5 7.8G 166M 7.2G 3% /tmp5 u4 W% ^1 Z& Z
/dev/sda3 9.7G 2.5G 6.8G 27% /usr
3 `; R1 ^* j# j! W6 P, @tmpfs 2.0G 0 2.0G 0% /dev/shm( M% E7 ]! m/ ?1 t( G
+ r8 a6 {8 Z! z+ S 参数 -h 表示使用「Human-readable」的输出,也就是在档案系统大小使用 GB、MB 等易读的格式。. \5 W$ m- I; M8 r: x1 s
2 n. I, t+ Q* J7 q8 a! r/ c 上面的命令输出的第一个字段(Filesystem)及最后一个字段(Mounted on)分别是档案系统及其挂入点。我们可以看到 /dev/sda1 这个分割区被挂在根目录下。8 M$ u3 G: {! S Z
?* v$ `3 E) E3 V% n 接下来的四个字段 Size、Used、Avail、及 Use% 分别是该分割区的容量、已使用的大小、剩下的大小、及使用的百分比。 FreeBSD下,当硬盘容量已满时,您可能会看到已使用的百分比超过 100%,因为 FreeBSD 会留一些空间给 root,让 root 在档案系统满时,还是可以写东西到该档案系统中,以进行管理。7 h* L, s8 C; t7 V! G- w- }! q
6 E, c u- h* N# Z3 j% D du:查询文件或文件夹的磁盘使用空间: \( N6 f7 h7 c( F. X# F& s" B
& M/ W: g+ \7 L( @+ W
如果当前目录下文件和文件夹很多,使用不带参数du的命令,可以循环列出所有文件和文件夹所使用的空间。这对查看究竟是那个地方过大是不利的,所以得指定深入目录的层数,参数:--max-depth=,这是个极为有用的参数!如下,注意使用“*”,可以得到文件的使用空间大小.* c P% \# P: w
3 L6 ~4 G: V% ^* [" a/ H0 V8 n8 t
提醒:一向命令比linux复杂的FreeBSD,它的du命令指定深入目录的层数却是比linux简化,为 -d。
- d$ V, [2 g. m( y- p% K5 [9 v% t' U9 Z2 c( ~/ j, u6 d
以下是代码片段:) l, F5 N5 U9 k# \) ?" y
$ e( v$ p: \! K( [ t- l/ L I[root@bsso yayu]# du -h --max-depth=1 work/testing
R1 ?4 c% u& M& z5 j7 q$ _( @1 ?27M work/testing/logs) a. S6 C$ d1 }+ H/ O5 f2 _1 U
35M work/testing
! ^7 B* H _- |1 A
/ i4 {0 _4 l$ w& M8 i8 j+ e[root@bsso yayu]# du -h --max-depth=1 work/testing/*
3 h4 b/ C1 i& S# M" |) L8.0K work/testing/func.php. f) y# |! e: E" M- X
27M work/testing/logs
4 @8 ~& B) H$ g z h! g8.1M work/testing/nohup.out8 g |$ r k/ E. W& r! N2 P5 Y0 M
8.0K work/testing/testing_c.php
. i9 e/ K5 ~3 ^0 H2 n12K work/testing/testing_func_reg.php4 _: l" k q; T; P/ v
8.0K work/testing/testing_get.php
7 a" w+ D% H$ y8.0K work/testing/testing_g.php
5 e; i# H- K2 O! g/ }8.0K work/testing/var.php
+ ]# K( i f1 F* }4 D% K+ P7 B5 Z& a7 A
[root@bsso yayu]# du -h --max-depth=1 work/testing/logs/
1 w n* B) ^' I! |1 \- E27M work/testing/logs/
2 @) E' I+ ^6 [2 ~0 }0 Q7 Y1 {# ], c+ j
[root@bsso yayu]# du -h --max-depth=1 work/testing/logs/*
3 Z! q9 e8 M- @4 {& `! k! L" d24K work/testing/logs/errdate.log_show.log8 [2 @2 H( I8 j; F* J n
8.0K work/testing/logs/pertime_show.log6 o1 f g$ G: r: h& Z
27M work/testing/logs/show.log
& M* X i3 [0 x+ B. W) R7 ~ c% W
) E$ c i: |; `( @ |
|