ext2文件系统
6 m8 K/ J8 d F
! D% ^* n$ b9 ` ext2文件系统的数据块大小一般为 1024B、2048B 或 4096B
" l, d$ W' M7 L& ^1 @ ext2文件系统采用的索引节点(inode):
7 {. `% W b2 l3 }/ u0 E( g& j 索引节点采用了多重索引结构,主要体现在直接指针和3个间接指针。直接指针包含12个直接指针块,它们直接指向包含文件数据的数据块,紧接在后面的3个间接指针是为了适应文件的大小变化而设计的。. _, g2 X6 {( X4 H
e.g: 假设数据块大小为1024B ,利用12个直接指针,可以保存最大为12KB的文件,当文件超过12KB时,则要利用单级间接指针,该指针指向的数据块保存有一组数据块指针,这些指针依次指向包含有实际数据的数据块,- d' x& t8 h0 d& h7 v
假如每个指针占用4B,则每个单级指针数据块可保存 1024/4=256 个数据指针,因此利用直接指针和单级间接指针可保存 1024*12+1024*256=268 KB的文件。当文件超过268KB时,再利用二级间接指针,直到使用三级间接指针。
9 t( o' m7 g1 e: U, [ 利用直接指针、单级间接指针、二级间接指针、三级间接指针可保存的最大文件大小为:/ B7 k+ J, c. R0 z% l1 b
1024*12+1024*256+1024*256*256+1024*256*256*256=16843020 KB,约 16GB) K1 x/ k3 t6 y. v: }3 v
若数据块大小为2048B,指针占4B,则最大文件大小为: 2048*12+2048*512+2048*512*512+2048*512*512*512=268,960,792 KB 约 268GB
# J: Z3 X x4 e- K/ k/ z8 ] 若数据块大小为4096B,指针占4B,则最大文件大小为: 4096*12+4096*1024+4096*1024*1024+4096*1024*1024*1024=4,299,165,744 KB ,约 4TB7 j9 \ x( k0 D0 W% K5 L W) t
注: 命令 tune2fs -l /dev/sda5 可查看文件系统7 L# e6 @6 I2 M$ b
ext2文件系统最大文件名长度: 255个字符
2 @5 f6 g& d7 C' m
- C+ E) c- b/ E) M ext2文件系统的缺点: 7 ]( I8 c0 c# W9 X/ X. u) `; y
ext2在写入文件内容的同时并没有同时写入文件meta-data, 其工作顺序是先写入文件的内容,然后等空闲时候才写入文件的meta-data。若发生意外,则文件系统就会处于不一致状态。/ V: n( s" T. G
在重新启动系统的时候,linux会启动 fsk ( file system check) 的程序,扫描整个文件系统并试图修复,但不提供保证。! p0 ?% t: F" E- \" h1 v
9、ext3文件系统:
, r" ~, f" a0 r q! ?
/ j- @. I& N& U9 }5 u ext3基于ext2的代码,所以磁盘格式与ext2相同,使用相同的元数据。
7 U7 D f+ u& P0 V6 } ext2文件系统无损转化为ext3文件系统: tune2fs -j /dev/sda6/ H0 i' o7 t2 k/ V! y2 G `) s
" f% D! e. ^3 [* ^; x
日志块设备( Journaling block device layer,JBD)完成ext3文件系统日志功能。JBD不是ext3文件系统所特有的,它的设计目标是为了向一个块设备添加日志功能。
3 Q. G- p9 Q( I( S 当一个文件修改执行时,ext3文件系统代码将通知JBD,称为一个事务(transaction)。发生意外时,日志功能具有的重放功能,能重新执行中断的事务。 |