|
当磁盘大小超过标准时会有报警提示,这时如果掌握df和du命令是非常明智的选择。
% i4 n% z, o& ]' m# S, ]* Q* i5 ~# ^: x* J0 i$ r7 ~- z
df可以查看一级文件夹大小、使用比例、档案系统及其挂入点,但对文件却无能为力。. I; h h( n7 W
du可以查看文件及文件夹的大小。% V$ n0 q, X- [- s" a
4 i6 \- Q4 ]# K% }" g$ F
两者配合使用,非常有效。比如用df查看哪个一级目录过大,然后用df查看文件夹或文件的大小,如此便可迅速确定症结。
4 n% `. |+ |$ ]: A
- f/ a% ^2 c# e7 n) ~ 下面分别简要介绍
' O R& f% O7 l# X: Y$ I% ` T; f4 h& u
df命令可以显示目前所有文件系统的可用空间及使用情形,请看下列这个例子:% w, v" a$ f- q/ K+ ^
0 s! J+ W# d# N4 y1 ?( X5 p
以下是代码片段:
- {6 \3 ]$ @. V, s5 S; u' m) @5 P; q7 H7 p6 [4 M( F7 g
[yayug@yayu ~]$ df -h
8 ~( s0 i! Q/ \+ g! Q+ J+ R' N1 JFilesystem Size Used Avail Use% Mounted on
7 y1 Q4 B+ G6 z2 c7 V9 c- J- n/dev/sda1 3.9G 300M 3.4G 8% /" N, P# l" R5 ^
/dev/sda7 100G 188M 95G 1% /data0
4 ^1 E- b r6 }0 }. I0 A" ?/dev/sdb1 133G 80G 47G 64% /data1, N% q5 t1 d# u; W4 Q
/dev/sda6 7.8G 218M 7.2G 3% /var5 g) t7 F2 X. R( l1 c. R
/dev/sda5 7.8G 166M 7.2G 3% /tmp
( k1 F$ ]# Y2 P# u/ j/dev/sda3 9.7G 2.5G 6.8G 27% /usr' p1 Y6 y' w, e0 d% K0 ?8 V c* c
tmpfs 2.0G 0 2.0G 0% /dev/shm
3 ?1 i+ m! l1 _
: B. X6 e; J9 _2 g% O 参数 -h 表示使用「Human-readable」的输出,也就是在档案系统大小使用 GB、MB 等易读的格式。
" j) h* {0 S0 U% V% B/ g4 u) W. j
/ h2 M1 k' ? f% r0 [. d% @: M 上面的命令输出的第一个字段(Filesystem)及最后一个字段(Mounted on)分别是档案系统及其挂入点。我们可以看到 /dev/sda1 这个分割区被挂在根目录下。: Q$ J7 ?. _3 x" J2 s0 a6 Y! V% \
; D( ~& U; [% K) `8 E/ Q- b' S
接下来的四个字段 Size、Used、Avail、及 Use% 分别是该分割区的容量、已使用的大小、剩下的大小、及使用的百分比。 FreeBSD下,当硬盘容量已满时,您可能会看到已使用的百分比超过 100%,因为 FreeBSD 会留一些空间给 root,让 root 在档案系统满时,还是可以写东西到该档案系统中,以进行管理。8 ~# s; n7 g$ ^2 I
4 p, Z( W' T1 r
du:查询文件或文件夹的磁盘使用空间
* O+ l- }4 B) q* u6 [8 r5 f# R# T: |% M# j9 j
如果当前目录下文件和文件夹很多,使用不带参数du的命令,可以循环列出所有文件和文件夹所使用的空间。这对查看究竟是那个地方过大是不利的,所以得指定深入目录的层数,参数:--max-depth=,这是个极为有用的参数!如下,注意使用“*”,可以得到文件的使用空间大小.
6 W+ W; [' }+ N' B8 c% F) g! ~* f1 ]0 l6 {$ T. F$ g# H! D2 z; G
提醒:一向命令比linux复杂的FreeBSD,它的du命令指定深入目录的层数却是比linux简化,为 -d。
& f& k- j C% f( S5 H, [9 J) [# V& m6 g* m" d0 W
以下是代码片段:9 u/ p: W9 H; E! b: M+ [! h
# V4 a" Z6 c8 z7 g" ]/ x: ? [[root@bsso yayu]# du -h --max-depth=1 work/testing
* G" C# z0 w, ~3 j27M work/testing/logs
: [' c% j& g+ D7 C! `+ W k35M work/testing
, q* I: [/ p5 b0 g
9 b w' |& ~$ ~" g% e# D; b) ~[root@bsso yayu]# du -h --max-depth=1 work/testing/*
/ [4 l9 h5 M. V, g; ]& p8.0K work/testing/func.php" i6 H, ?/ e. q/ `* X
27M work/testing/logs
2 _/ b& W4 i3 j: H0 d& s8.1M work/testing/nohup.out
( h, O' H+ X m3 W9 v8.0K work/testing/testing_c.php Y3 B a: j6 Q# L
12K work/testing/testing_func_reg.php
) h7 J6 g6 N5 k3 d8.0K work/testing/testing_get.php1 M8 X; d7 O' V" M
8.0K work/testing/testing_g.php! E. L" @' b. i. M5 [
8.0K work/testing/var.php, G0 S* u4 ?( Z% M
! S' s% ?* M! p/ h+ }. s$ }[root@bsso yayu]# du -h --max-depth=1 work/testing/logs/0 y5 f5 D6 |6 n, T5 W7 A# c- u
27M work/testing/logs/
7 A C4 k; W/ L
L" A! z+ E D' [/ o B8 w[root@bsso yayu]# du -h --max-depth=1 work/testing/logs/*) C' y3 Z+ |/ B! M* A. e
24K work/testing/logs/errdate.log_show.log
! L. e3 j; P0 P" X- y' a' z8.0K work/testing/logs/pertime_show.log
) U8 p& }8 R7 F: V2 F27M work/testing/logs/show.log
h: B' \* \. c( _
" v+ ?" q% b! `3 \6 \, ~$ L |
|