|
|
当磁盘大小超过标准时会有报警提示,这时如果掌握df和du命令是非常明智的选择。
2 T' t$ \ g& t3 q5 [
# `& M0 `- B- B df可以查看一级文件夹大小、使用比例、档案系统及其挂入点,但对文件却无能为力。9 Y% r- [$ ~% J+ T
du可以查看文件及文件夹的大小。4 \" d6 j! Y4 k3 q# g) @
# N% Y3 a2 n: n$ q, l: T3 H
两者配合使用,非常有效。比如用df查看哪个一级目录过大,然后用df查看文件夹或文件的大小,如此便可迅速确定症结。- G3 o: Z% R" k9 k1 P6 C/ K. D1 i. I
l3 b' `, ` r7 Q! T5 r6 g$ i% I 下面分别简要介绍# I3 l$ N# S/ o( ]' A( d+ d4 ^
, U; t( w, V1 \ df命令可以显示目前所有文件系统的可用空间及使用情形,请看下列这个例子:: N5 { x3 \8 o( V3 ~1 m
) T3 \- `6 I, j0 y以下是代码片段:
, B' [" D! d+ K( L- K3 A. H' a% @4 {8 Q4 v! o6 |: S# b- y
[yayug@yayu ~]$ df -h, m9 O: t& i) `* O% Z y
Filesystem Size Used Avail Use% Mounted on7 d2 h; v6 t3 L; ]9 r& b
/dev/sda1 3.9G 300M 3.4G 8% /
- U$ S% ]9 ?7 ~* ~3 {% w/dev/sda7 100G 188M 95G 1% /data09 u; i, w* {) x/ p4 c7 S/ d. q
/dev/sdb1 133G 80G 47G 64% /data1
5 E% ]' }/ x8 k% B# R @) C1 _- T/dev/sda6 7.8G 218M 7.2G 3% /var
/ f( X! K2 L& @9 n; T2 @2 ^/dev/sda5 7.8G 166M 7.2G 3% /tmp
9 `% U5 e* n9 f% y( c9 L0 t/dev/sda3 9.7G 2.5G 6.8G 27% /usr
8 h' X, I9 Q$ F- J: D2 W0 V3 W& h3 Stmpfs 2.0G 0 2.0G 0% /dev/shm
9 G: N. P" K* t9 C1 L- ?( @4 b% k' t: D# K
参数 -h 表示使用「Human-readable」的输出,也就是在档案系统大小使用 GB、MB 等易读的格式。# _. P1 ^( y* W) t
; ~. b# ~9 e" n; {+ y
上面的命令输出的第一个字段(Filesystem)及最后一个字段(Mounted on)分别是档案系统及其挂入点。我们可以看到 /dev/sda1 这个分割区被挂在根目录下。/ I3 ^+ k' S' J6 U
; y: W# Z3 a$ I9 z
接下来的四个字段 Size、Used、Avail、及 Use% 分别是该分割区的容量、已使用的大小、剩下的大小、及使用的百分比。 FreeBSD下,当硬盘容量已满时,您可能会看到已使用的百分比超过 100%,因为 FreeBSD 会留一些空间给 root,让 root 在档案系统满时,还是可以写东西到该档案系统中,以进行管理。 w( e, Z, o7 i+ J, `3 d3 v- \
& W6 r" M9 X) k* O du:查询文件或文件夹的磁盘使用空间
) m; ?) b( K# x3 j, @
' }/ R3 I+ m+ i T- v 如果当前目录下文件和文件夹很多,使用不带参数du的命令,可以循环列出所有文件和文件夹所使用的空间。这对查看究竟是那个地方过大是不利的,所以得指定深入目录的层数,参数:--max-depth=,这是个极为有用的参数!如下,注意使用“*”,可以得到文件的使用空间大小.
! Y: I: k0 }$ R5 X+ x9 l$ i U8 {* Q8 }
提醒:一向命令比linux复杂的FreeBSD,它的du命令指定深入目录的层数却是比linux简化,为 -d。
1 Q0 T5 Q. T* y+ U2 q. I4 A# n8 M: z8 B- q4 a4 c( g: _
以下是代码片段:
, A- Q3 S3 ?2 @/ k9 \ b: P6 N) {, p3 y; q: i7 H
[root@bsso yayu]# du -h --max-depth=1 work/testing2 C$ F/ s: _5 S
27M work/testing/logs' f# |- R/ \* j# k
35M work/testing3 U& c" `, @4 B T1 d
. \) m! F* h' M8 C6 r[root@bsso yayu]# du -h --max-depth=1 work/testing/*$ k" ~9 R# T+ j2 A) Y4 |
8.0K work/testing/func.php" t/ }4 g) I, E0 e9 r$ m/ j
27M work/testing/logs- |4 _+ r4 n$ z- [$ b4 c, I
8.1M work/testing/nohup.out0 D! g" c, C2 X" z
8.0K work/testing/testing_c.php. ~3 i4 V x+ V. Z, D
12K work/testing/testing_func_reg.php
- S L7 b0 R% |" @; F8.0K work/testing/testing_get.php
2 j# Z4 P6 R6 C" p8.0K work/testing/testing_g.php: d! G; n! C( ~( z8 H I* ?
8.0K work/testing/var.php0 ?, n8 L/ W3 |! M
- E) X" a, u7 Y2 c1 J( S* K4 T[root@bsso yayu]# du -h --max-depth=1 work/testing/logs/* T6 I, q% b3 |( A& r5 y7 t
27M work/testing/logs/
9 ?) J. n+ J, m/ E) b: f8 p
2 T) s0 `, c( n5 @5 C[root@bsso yayu]# du -h --max-depth=1 work/testing/logs/*
! E' g" s* q- p# W; L24K work/testing/logs/errdate.log_show.log
7 t) x0 |! b' ^$ }* M/ ^8 S$ H8.0K work/testing/logs/pertime_show.log7 N3 Q. H7 c6 t# j3 J' y8 A
27M work/testing/logs/show.log
; s: S- o3 \, H( Y: o3 [+ R# {9 `1 s% R2 e
|
|