|
|
当磁盘大小超过标准时会有报警提示,这时如果掌握df和du命令是非常明智的选择。& b: v: O# y2 A6 ~" ~/ f
6 M3 \4 f- j2 Z* J! `' L5 L
df可以查看一级文件夹大小、使用比例、档案系统及其挂入点,但对文件却无能为力。
% w) s" X3 ^0 B X du可以查看文件及文件夹的大小。4 R% O6 ], L* H y' o- f0 ~( v3 a
3 C5 h6 Z' G$ q: y+ F, I+ _ 两者配合使用,非常有效。比如用df查看哪个一级目录过大,然后用df查看文件夹或文件的大小,如此便可迅速确定症结。
4 \7 `' a/ V& X" W" z! u K7 n5 w8 @+ A$ ~. E# C+ n* R2 S$ a
下面分别简要介绍
4 J1 U# q' W" m# M- h+ ]* M4 J' h/ b0 F' ?
df命令可以显示目前所有文件系统的可用空间及使用情形,请看下列这个例子:
8 v% V, t* J& b/ ], m" l) Y( D! y* ?& ^; _6 W: a
以下是代码片段:( J9 z4 ]! l& A' c
0 {& N4 w% y ^9 G/ }' N[yayug@yayu ~]$ df -h: }! z6 h- T) n0 a M: V6 N2 \. l
Filesystem Size Used Avail Use% Mounted on" j3 u; q$ z8 {0 M
/dev/sda1 3.9G 300M 3.4G 8% // s) N9 F2 n/ w. v5 k, y& q$ r" }
/dev/sda7 100G 188M 95G 1% /data0
/ L9 m) Z( G3 E) l- j/dev/sdb1 133G 80G 47G 64% /data1* x2 E, W. Y. B) k- ^! l
/dev/sda6 7.8G 218M 7.2G 3% /var
1 r, M5 D) F! f* O: }1 n4 c/dev/sda5 7.8G 166M 7.2G 3% /tmp
4 f/ O( R6 g) j0 z+ C( \/dev/sda3 9.7G 2.5G 6.8G 27% /usr
) d N! `+ V. q0 J; I, e0 f0 e1 otmpfs 2.0G 0 2.0G 0% /dev/shm% r5 S, s+ A5 |) n
3 Y4 J+ ]- C- `2 S- K
参数 -h 表示使用「Human-readable」的输出,也就是在档案系统大小使用 GB、MB 等易读的格式。
! t; K+ S# Q. E0 p: F# O! s4 O( q) C$ }! |3 `9 O2 y/ c4 {
上面的命令输出的第一个字段(Filesystem)及最后一个字段(Mounted on)分别是档案系统及其挂入点。我们可以看到 /dev/sda1 这个分割区被挂在根目录下。
0 S1 q3 |; p! N+ |; J
' O2 v" O! x! H, R. w6 {: y 接下来的四个字段 Size、Used、Avail、及 Use% 分别是该分割区的容量、已使用的大小、剩下的大小、及使用的百分比。 FreeBSD下,当硬盘容量已满时,您可能会看到已使用的百分比超过 100%,因为 FreeBSD 会留一些空间给 root,让 root 在档案系统满时,还是可以写东西到该档案系统中,以进行管理。* Z7 h1 q9 Q6 D. i# ]* h/ @) k; v
4 ^" X; l; B: u, H; G2 c9 ]* `6 W
du:查询文件或文件夹的磁盘使用空间, R! u0 ^" u3 L' U- N# t/ t9 t
5 o/ } A9 s/ o4 O 如果当前目录下文件和文件夹很多,使用不带参数du的命令,可以循环列出所有文件和文件夹所使用的空间。这对查看究竟是那个地方过大是不利的,所以得指定深入目录的层数,参数:--max-depth=,这是个极为有用的参数!如下,注意使用“*”,可以得到文件的使用空间大小.
' \. o" d8 I' _
& ]. H& |* w" z9 d! @" d) r- v 提醒:一向命令比linux复杂的FreeBSD,它的du命令指定深入目录的层数却是比linux简化,为 -d。
, k, E4 c/ j8 f* U( a" }, m5 d* N2 l9 O: r, w z4 i" S
以下是代码片段:
# I/ H. o* ?; f. P. k0 l% i6 c; y. r# U' l
[root@bsso yayu]# du -h --max-depth=1 work/testing
0 f9 E/ o! }( x7 ?9 h27M work/testing/logs
* H ~4 c4 q% N2 d. o35M work/testing
- L8 O+ W! `4 `0 B' |" [+ s/ J# p$ m8 P% j6 J- S, g, u+ ?! R
[root@bsso yayu]# du -h --max-depth=1 work/testing/*
+ X$ b" k1 _9 I. q* c) w0 y8.0K work/testing/func.php
/ }5 Y5 ^' \6 m# E; D* J27M work/testing/logs
8 L' I; Y6 t4 ^( {/ g4 |$ i8.1M work/testing/nohup.out
1 D, Y0 U, f) Y8 C+ H6 \8.0K work/testing/testing_c.php- f+ E+ j: f2 f2 u
12K work/testing/testing_func_reg.php; L* P8 q2 W1 u9 t" @
8.0K work/testing/testing_get.php; C9 X7 i' G& T. Y1 E2 J2 l
8.0K work/testing/testing_g.php2 ~+ W* ~2 u# h+ |. f) Z0 F
8.0K work/testing/var.php& i, ?2 [; f, h1 C9 E& k+ e
6 n* E4 W7 T$ \[root@bsso yayu]# du -h --max-depth=1 work/testing/logs/. @8 t p7 G# c- x
27M work/testing/logs/
1 f: {* t. q+ C4 l# J
/ b* @2 F" c, k[root@bsso yayu]# du -h --max-depth=1 work/testing/logs/*
, t0 Y5 b: F8 k( ?/ H: c24K work/testing/logs/errdate.log_show.log
- |0 F2 j$ S( e$ e8.0K work/testing/logs/pertime_show.log
% H- `5 | r/ e2 t/ X" m27M work/testing/logs/show.log$ b0 ~9 _3 Y2 [6 I$ l5 Z2 l7 b
" c& o7 m- b* v6 w. D, S. e |
|