|
|
当磁盘大小超过标准时会有报警提示,这时如果掌握df和du命令是非常明智的选择。
0 m0 w6 `. C+ v' ^
5 T* F/ a) d! n% d) B df可以查看一级文件夹大小、使用比例、档案系统及其挂入点,但对文件却无能为力。1 l9 T" r4 r, |
du可以查看文件及文件夹的大小。: Q2 L8 h9 J, j$ i
7 G- r$ ~1 P% N/ S3 {, ~ 两者配合使用,非常有效。比如用df查看哪个一级目录过大,然后用df查看文件夹或文件的大小,如此便可迅速确定症结。
9 m1 h6 N$ s6 {+ d/ C* s+ }6 M* f, k$ W
下面分别简要介绍. E9 g2 l/ X/ N% }6 s5 i
/ F2 e! S& Y$ d" `0 s6 ]( ^* X df命令可以显示目前所有文件系统的可用空间及使用情形,请看下列这个例子:
: W- f! _; u+ ^% P9 I3 N9 ]: T
8 \6 [; n9 Y8 I, Y Q, K& J以下是代码片段:9 z4 W8 s$ |4 p
* |' B: C% w3 n- c$ g" z
[yayug@yayu ~]$ df -h
9 g' J; j' r& `# d; bFilesystem Size Used Avail Use% Mounted on8 S, m5 H! G- a4 `
/dev/sda1 3.9G 300M 3.4G 8% /* A6 d# b' ]! E
/dev/sda7 100G 188M 95G 1% /data0( [6 x P+ b/ Z0 G
/dev/sdb1 133G 80G 47G 64% /data16 ?3 }+ t; I) o, P; M
/dev/sda6 7.8G 218M 7.2G 3% /var
( ] }) x: h7 `3 |8 r3 E' j/dev/sda5 7.8G 166M 7.2G 3% /tmp0 t( A" l' S4 z! c: B
/dev/sda3 9.7G 2.5G 6.8G 27% /usr
& C) j1 }- H J. L% }tmpfs 2.0G 0 2.0G 0% /dev/shm/ r k: B* j1 \; Y& `
4 c" K2 n, H- u4 Z# l; b
参数 -h 表示使用「Human-readable」的输出,也就是在档案系统大小使用 GB、MB 等易读的格式。+ Z8 n \/ O/ t
5 U2 O. t6 ?2 A5 O 上面的命令输出的第一个字段(Filesystem)及最后一个字段(Mounted on)分别是档案系统及其挂入点。我们可以看到 /dev/sda1 这个分割区被挂在根目录下。- Y' `7 O8 U. t* p
* z `$ j' \ N: @
接下来的四个字段 Size、Used、Avail、及 Use% 分别是该分割区的容量、已使用的大小、剩下的大小、及使用的百分比。 FreeBSD下,当硬盘容量已满时,您可能会看到已使用的百分比超过 100%,因为 FreeBSD 会留一些空间给 root,让 root 在档案系统满时,还是可以写东西到该档案系统中,以进行管理。$ k; v) ~, _# u8 h9 B' ?
/ H. a) \+ n2 J7 z du:查询文件或文件夹的磁盘使用空间; @# y8 a. `4 R
6 U( d1 w/ Y/ F( K) E c- q1 d# [ 如果当前目录下文件和文件夹很多,使用不带参数du的命令,可以循环列出所有文件和文件夹所使用的空间。这对查看究竟是那个地方过大是不利的,所以得指定深入目录的层数,参数:--max-depth=,这是个极为有用的参数!如下,注意使用“*”,可以得到文件的使用空间大小.4 c% u- H+ l1 b8 {6 q
& }" V0 Z3 f1 t3 B: A 提醒:一向命令比linux复杂的FreeBSD,它的du命令指定深入目录的层数却是比linux简化,为 -d。8 T' {+ e% r/ o* `' D# i
( o6 ?( E7 z, c$ D" I% d
以下是代码片段:% F: w) g1 n) l1 I* T
' t" e3 O& x/ j( w8 F( y1 N[root@bsso yayu]# du -h --max-depth=1 work/testing; }3 u, E' W" T e
27M work/testing/logs% n A! p3 J% x/ A" V% V5 Z- i
35M work/testing
$ \& c" f6 r8 H4 ]5 Z* a X, B4 k: {1 u7 {7 \- _
[root@bsso yayu]# du -h --max-depth=1 work/testing/*
# l7 f9 G; W' E* f- Y l8.0K work/testing/func.php
$ r# m& n' p* Z1 w* T27M work/testing/logs; M: F g7 g f6 Y) |
8.1M work/testing/nohup.out
9 w" k9 S' k8 P$ B8.0K work/testing/testing_c.php
' ?& a5 v" r$ B! {# i0 y/ F12K work/testing/testing_func_reg.php# I5 i1 C1 C) v4 L1 c7 j
8.0K work/testing/testing_get.php
+ n# [& ]: ?5 ?) |& T8.0K work/testing/testing_g.php; N( B& m6 E( Y, R! X. h! A
8.0K work/testing/var.php! C0 G! d3 S5 V) j$ V
9 o9 _+ {; [* d# ~+ t[root@bsso yayu]# du -h --max-depth=1 work/testing/logs/: S$ w9 E$ i. e! M% b
27M work/testing/logs/
/ A, M* ?$ E$ Y' d
9 E/ r3 C2 _. F$ U7 l[root@bsso yayu]# du -h --max-depth=1 work/testing/logs/*: c( Y4 Q, q* c; [0 v% J
24K work/testing/logs/errdate.log_show.log' q0 z' P7 a+ K9 V2 @* B5 O7 Z
8.0K work/testing/logs/pertime_show.log" B/ A- J$ `& m8 G# ?4 B8 ]
27M work/testing/logs/show.log
5 Z" p" ^. Y3 Y9 w7 _6 ?7 H# _% h: H
+ g" ~; g! I) C |
|