Linux文件系统的最基本数据结构:inode和block

    • Linux文件系统的最基本数据结构:inode和block

      • 为什么有inode和block

      • inode

      • block

      • 创建目录或文件

      • 使用场景

      • 查看本机的文件系统信息

Linux文件系统的最基本数据结构:inode和block

为什么有inode和block

由于Linux系统是多用户多的,所以文件系统类型多样化是在所难免的。从ext2开始,是将文件属性和文件内容分开存储的,分别由inode和block来负责。

inode

用于存储文件的各属性,包括:

- 所有者信息:文件的owner,group;
- 权限信息:read、write和excite;
-时间信息:建立或改变时间(ctime)、最后读取时间(atime)、最后修改时间(mtime);
- 标志信息:一些flags;
- 内容信息:type,size,以及相应的block的位置信息。

//注意:不记录文件名或目录名,文件名或目录名记录在文件所在目录对应的block里。

block

用来存储文件的内容。

创建目录或文件

1、当创建一个目录时,文件系统会为该目录分配一个inode和至少一个block。该inode记录该目录的属性,并指向那块block。该block记录该目录下相关联的文件或目录的关联性和名字。

2、当创建一个文件时,文件系统会为该文件分配至少一个inode和与该文件大小相对应的数量的block。该inode记录该文件的属性,并指向block。

3、如果一个目录中的文件数太多,以至于1个block容纳不下这么多文件时,Linux的文件系统会为该目录分配更多的block。

分区 
(1)分区结构

分区(partition)在被Linux的文件系统(比如ext2)格式化的时候,会分成inode table和block table两部分,且大小都是固定的。该分区的所有inode都在inode table里,所有block都在block table里。

(2)块大小

ext2允许的block size为1024bytes、2048bytes和4096bytes。

(3)inode大小

ext2一般默认给inode预设的大小为128bytes。

(4)预设分区

一个T bytes的分区,设定每个block为B bytes,每个inode为I bytes。如果假设平均每个文件占用两个block的话,那么inode的数量就应该设定为T/(2B+I)个,即inode table为T*I/(2B+I) bytes,block table为T*B/(2B+I) bytes。所以一个分区的文件系统所能容纳的文件数量,被限制于该分区的文件系统的inode area中的inode数。

如果一个分区大小为1GB,每个block为4KB,一个inode为128B,并假设平均每个文件占用2个block。那么inode的数量为1GB/(8KB+128B)=129055.5,即129055。那么inode table的大小为129055*128B=15.75MB。所以按照这样的规划,如果一个1GB的磁盘,那么格式化后,就已经有15.75MB被使用了。

使用场景

大文件应用场景:block设置的小一些,inode设置的多一些。比如新闻组、BBS等。 
小文件应用场景:block设置的大一些,inode设置的少一些。比如图片分享网站。

查看本机的文件系统信息

使用dumpe2fs命令可以查看分区的文件系统的相关信息。比如我在我的一台测试机上查看sda1,可以输入:

dumpe2fs /dev/sda1

会得到如下内容,一些信息已经标注在注释里了。

(1)文件系统基本信息

#该分区的文件系统的名称
Filesystem volumn name: MAIN
#上次的挂载点
Last mounted on: <not available>
#文件系统的通用唯一标识符
Filesystem UUID: <none>
#文件系统的
Filesystem magic number: 0xEF53
#修订版本号
Filesystem revision #: 1 (dynamic)
Filesystem features: has_journal needs_recovery
Filesystem flags: signed_directory_hash
Default mount options: (none)
#文件系统状态
Filesystem state: clean
#发生错误后的行为
Errors behavior: Continue
#操作系统
Filesystem OS type: Linux

(2)结构信息

#Inode总数
Inode count: 1313312
#Block总数
Block count: 1313305
#保留block数
Reserved block count: 65665
#空闲block数
Free blocks: 979164
#空闲inode数
Free inodes: 1298415  
#第一个block的编号
First block: 0
#block的大小
Block size: 4096
#fragment的大小
Fragment size: 4096
#每个group的block数是32K个
Blocks per group: 32768
#每个group的fragment数是32K个
Fragments per group: 32768
#每个group的inode数
Inodes per group: 32032
#每个group的inode blocks
Inode blocks per group: 1001

一个100M(100000K)文件的磁盘分区,分别写入1K文件与写入1M文件,分别可以写多少个? 
答:最多写入9103个文件

分析

设置默认块大小1k
100M/(1k+128B)
// 转换成b后除
104857600/1152
最多9103
100M被格式化以后有11kb创建了inode表
//用104857600除以9103=11519(11kb)

原创文章,作者:M20_he,如若转载,请注明出处:http://www.178linux.com/43527

(8)
M20_heM20_he
上一篇 2016-09-06
下一篇 2016-09-06

相关推荐

  • 用户与组管理

    如何成为linux用户?     在linux系统中,要想从系统中获取资源、对系统进行管理和控制,就需要向系统申请一个账号,从而实现特定用途,当申请到账号后,要对它设置口令,这样用户账号就申请成功了,然后可以登陆系统,当用户登陆系统时,需要通过系统的认证,认证成功后才给予授权,在用户的使用过程中还会对用户进行审计。 为什么要设置…

    Linux干货 2016-08-08
  • Linux之函数

      Linux之函数     函数介绍函数function是由若干条shell命令组成的语句块,实现代码重用和模块化编程。它与shell程序形式上是相似的,不同的是它不是一个单独的进程,不能独立运行,而是shell程序的一部分。函数和shell程序比较相似,区别在于:Shell程序在子Shell中运行而Shell函数在…

    Linux干货 2016-08-25
  • 设计模式 ( 十七) 状态模式State(对象行为型)

    设计模式 ( 十七) 状态模式State(对象行为型) 1.概述 在软件开发过程中,应用程序可能会根据不同的情况作出不同的处理。最直接的解决方案是将这些所有可能发生的情况全都考虑到。然后使用if… ellse语句来做状态判断来进行不同情况的处理。但是对复杂状态的判断就显得“力不从心了”。随着增加新的状态或者修改一个状体(if else(或swit…

    Linux干货 2015-07-27
  • bash编程初体验(二)

    bash编程初体验(二) read if case 概述 在本篇文章中,我们将介绍bash编程中有关if语句的简单用法,if语句的基本思路是判断给定的条件是否满足,即结果是真还是假,从而选择执行哪种操作。如此,如果条件为真,if会执行一种指令,如果条件为假,if会选择执行另一种指令,这种执行就是所谓的选择结构,它能够改变命令的基本顺序流结构,以选择流的形式运…

    Linux干货 2016-08-19
  • 关于大型网站技术演进的思考(九)–网站静态化处理–总述(1)

    原文出处: 夏天的森林    在存储瓶颈的开篇我提到像hao123这样的导航网站只要它部署的web服务器数量足够,它可以承载超大规模的并发访问量,如果是一个动态的网站,特别是使用到了数据库的网站是很难做到通过增加web服务器数量的方式来有效的增加网站并发访问能力的。但是现实情况是像淘宝、京东这样的大型动态网站在承担高并发的情况下…

    Linux干货 2015-03-11
  • 是否

    是否

    Linux干货 2016-08-22