Linux文件系统

一、文件系统结构

1硬盘内部结构

在这里插入图片描述

硬盘的内部是金属盘片,将圆形的盘片划分成若干个扇形区域,这就是扇区。若干个扇区就组成整个盘片。为什么要分扇区?是逻辑化数据的需要,能更好的管理硬盘空间。 以盘片中心为圆心,把盘片分成若干个同心圆,那每一个划分圆的“线条”,就称为磁道
硬盘内的盘片有两个面,都可以储存数据,而硬盘内的盘片往往不止一张,常见的有两张,那么,两张盘片中相同位置的磁道,就组成一个“柱面”,盘片中有多少个磁道,就有多少个柱面。盘片两面都能存数据,要读取它,必须有磁头,所以,每一个面,都有一个磁头,一张盘片就有两个磁头
硬盘的存储容量=磁头数×磁道(柱面)数×每道扇区数×每道扇区字节数。
磁道从外向内自0开始顺序进行编号,各个磁道上的扇区数是在硬盘格式化时确定的。
文件储存在硬盘上,硬盘的最小存储单位叫做"扇区"(Sector)。每个扇区储存512字节(相当于0.5KB)。
比较古老的CHS (Cylinder/Head/Sector :磁头(Heads)、柱面(Cylinder)、扇区(Sector))结构体系. 因为很久以前,在硬盘的容量还非常小的时候,人们采用与软盘类似的结构生产硬盘。也就是硬盘盘片的每一条磁道都具有相同的扇区数,由此产生了所谓的3D参数,即是磁头数(Heads)、柱面数(Cylinders)、扇区数(Sectors)以及相应的3D寻址方式。

老式的硬盘磁道扇区结构
在这里插入图片描述
每个磁道的扇区都一样,这样外磁道整个弧长要大于内部的扇区弧长,因而其磁记录密度就要比内部磁道的密度要小。最终,导致了外部磁道的空间浪费

现在硬盘

现在硬盘都采用这种技术:ZBR(Zoned Bit Recording)区位记录
ZBR 是一种物理优化硬盘存储空间的方法,此方法通过将更多的扇区放到磁盘的外部磁道而获取更多存储空间
在这里插入图片描述
使用ZBR 区位记录法做的磁盘有以下特点:读外圈的数据快,读内圈的数据慢,所以测试硬盘经常看到读取速度越来越慢的曲线图就很正常了

在这里插入图片描述

所以:操作系统安装在最外面速度最快
磁盘写数据时,先从外面往里

2簇和block

windows的簇就是Linux系统中的block(块大小)

1、创建新的记事本文件,输入一些内容“我是Linux高手”,然后保存
在这里插入图片描述
2、右击属性查看大小,说明NTFS文件系统中默认的簇大小为4KB
在这里插入图片描述
3、Linux系统中

[root@qianshuiliyu ~]# stat /etc/passwd
  文件:"/etc/passwd"
  大小:2354      	块:8          IO 块:4096   普通文件
设备:fd00h/64768d	Inode:17664892    硬链接:1
权限:(0644/-rw-r--r--)  Uid:(    0/    root)   Gid:(    0/    root)
最近访问:2022-02-02 08:03:28.959000018 +0800
最近更改:2022-01-26 13:02:33.856246586 +0800
最近改动:2022-01-26 13:02:33.857246589 +0800
创建时间:-

在这里插入图片描述

3文件系统结构

Linux文件系统由三部分组成 : 文件名,inode,block
Linux文件系统: ext3,ext4,xfs
windows文件系统: FAT32,NTFS

1inode的内容

inode包含文件的元信息
文件的字节数
文件拥有者的User ID
文件的Group ID
文件的读、写、执行权限
文件的时间戳,共有三个:ctime指inode上一次变动的时间,mtime指文件内容上一次变动的时间,atime指文件上一次打开的时间
链接数,即有多少文件名指向这个inode
文件数据block的位置

stat命令,查看某个文件的inode信息

[root@qianshuiliyu ~]# stat /etc/passwd
  文件:"/etc/passwd"
  大小:2354      	块:8          IO 块:4096   普通文件
设备:fd00h/64768d	Inode:17664892    硬链接:1
权限:(0644/-rw-r--r--)  Uid:(    0/    root)   Gid:(    0/    root)
最近访问:2022-02-02 08:03:28.959000018 +0800
最近更改:2022-01-26 13:02:33.856246586 +0800
最近改动:2022-01-26 13:02:33.857246589 +0800
创建时间:-

在这里插入图片描述

三个时间
mtimemodify time 修改文件内容的时间
atimeaccess time 访问文件内容的时间
ctime指inode上一次文件属性变动的时间,change time , 比如: chmod +x a.sh

2inode的大小

inode也会消耗硬盘空间,所以硬盘格式化的时候,操作系统自动将硬盘分成两个区域。一个是数据区,存放文件数据;另一个是inode区(inode table),存放inode所包含的信息。
每个inode节点的大小,一般是128字节或256字节。inode节点的总数,在格式化时就给定,假定在一块1GB的硬盘中,每个inode节点的大小为128字节,每1KB就设置一个inode,那么inode table的大小就会达到128MB,占整块硬盘的12.8%

3inode号码

每个inode都有一个号码,操作系统用inode号码来识别不同的文件。
Unix/Linux系统内部不使用文件名,而使用inode号码来识别文件。对于系统来说,文件名只是inode号码便于识别的别称或者绰号。表面上,用户通过文件名,打开文件。实际上,系统内部这个过程分成三步:首先,系统找到这个文件名对应的inode号码;其次,通过inode号码,获取inode信息;最后,根据inode信息,找到文件数据所在的block,读出数据。

1、使用ls -i命令,可以看到文件名对应的inode号码

[root@qianshuiliyu ~]# ls -i /etc/passwd
17664892 /etc/passwd

2、查看每个硬盘分区的inode总数和已经使用的数量,可以使用df命令

[root@qianshuiliyu ~]# df -i
文件系统                  Inode 已用(I) 可用(I) 已用(I)% 挂载点
devtmpfs                 120203     420  119783       1% /dev
tmpfs                    124459       1  124458       1% /dev/shm
tmpfs                    124459     959  123500       1% /run
tmpfs                    124459      16  124443       1% /sys/fs/cgroup
/dev/mapper/centos-root 8910848  160109 8750739       2% /
/dev/sdb1               2621440       4 2621436       1% /sdb1
/dev/sda1                524288     340  523948       1% /boot
tmpfs                    124459       9  124450       1% /run/user/42
tmpfs                    124459       1  124458       1% /run/user/0

由于每个文件都必须有一个inode,因此有可能发生inode已经用光,但是硬盘还未存满的情况。这时,就无法在硬盘上创建新文件

4目录文件

Unix/Linux系统中,目录(directory)也是一种文件。打开目录,实际上就是打开目录文件
目录文件的结构非常简单,就是一系列目录项的列表。每个目录项,由两部分组成:所包含文件的文件名,以及该文件名对应的inode号码。

[root@qianshuiliyu ~]# ls -i /etc/ -d
16777281 /etc/
[root@qianshuiliyu ~]# ls -i /etc/

5block块大小

block 是真正存储数据的地方。
block是 文件系统 中最小的存储单位
扇区 是 磁盘 中最小的存储单位
在linux下中叫:block,在windows中叫:簇

操作系统读取硬盘的时候,不会一个个扇区(512字节)地读取,这样效率太低,而是一次性连续读取多个扇区,即一次性读取一个"块"(block)。这种由多个扇区组成的"块",是文件存取的最小单位。"块"的大小,最常见的是1KB,即连2个 sector扇区组成一个 block。或4K

1、格式化修改磁盘,修改簇大小
在这里插入图片描述
在这里插入图片描述
簇和block越大,速度越快,节约寻址时间,但是空间浪费

inode号唯一标识一个文件(一个文件系统里面)
inode用完了,文件就不能创建了
inode数据量设置大一些:可以创建多个文件。占用空间比较大
inode数据量设置小一些:可以创建很少文件。占用空间比较小
block设置大:效率高,利用率低。
block设置小:效率低,利用率高。

6文件的硬链接和软链接

Linux链接分两种,一种被称为硬链接(Hard Link),另一种被称为软链接,即符号链接(Symbolic Link)。默认情况下,ln命令产生硬链接。
【硬连接】:硬连接指通过索引节点号来进行连接。inode是可以对应多个文件名的
在Linux的文件系统中,保存在磁盘分区中的文件不管是什么类型都给它分配一个编号,称为索引节点号(Inode Index)。
在Linux中,多个文件名可以指向同一索引节点。一般这种连接就是硬连接。
硬连接的作用是允许一个文件拥有多个有效路径名,这样用户就可以建立硬连接到重要文件,以防止“误删”的功能。
只删除一个连接并不影响索引节点本身和其它的连接,只有当最后一个连接被删除后,文件的数据块及目录的连接才会被释放。也就是说,文件真正删除的条件是与之相关的所有硬连接文件均被删除
【软连接】:另外一种连接称之为符号连接(Symbolic Link),也叫软连接。软链接文件有类似于Windows的快捷方式。它实际上是一个特殊的文件。在符号连接中,文件实际上是一个文本文件,其中包含的有另一文件的位置信息

软连接硬链接
相当于windows中的快捷方式硬链接的原理就是多个文件名指向同一个inode,因此多个文件名共用一个inode号,达到共享与备份的目的,源文件被删除,不影响链接文件的正常使用
源文件被删除,链接文件失效硬链接不能针对目录创建
能针对目录和跨分区创建软链接硬链接不能跨分区进行创建
能跨分区创建(源文件必须写绝对路径)无法针对目录,跨分区无法实现。因为每个分区都有自己独立的INDOE编号

为什么刚创建的一个目录,链接数就是2
默认新一个空目录,此目录的第二字段就是2(包含两个隐藏目录,因为每一个目录都有一个指向它本身的子目录"." 和指向它上级目录的子目录"…")

[root@qianshuiliyu ~]# ll -d /mnt/
drwxr-xr-x. 2 root root 6 411 2018 /mnt/
[root@qianshuiliyu ~]# ll -id /mnt/
16778318 drwxr-xr-x. 2 root root 6 411 2018 /mnt/
[root@qianshuiliyu ~]# ll -id /mnt/.

7inode的特殊作用

inode号码与文件名分离,这种机制导致了一些Unix/Linux系统特有的现象
有时,文件名包含特殊字符,无法正常删除。这时,直接删除inode节点,就能起到删除文件的作用
移动文件或重命名文件,只是改变文件名,不影响inode号码
打开一个文件以后,系统就以inode号码来识别这个文件,不再考虑文件名。因此,通常来说,系统无法从inode号码得知文件名

为什么每次修改完服务器配置文件后,都需要重新加载一下配置文件
因为vim每次修改完后,Inode号都会变

[root@qianshuiliyu ~]# ll -i /etc/passwd
17664892 -rw-r--r-- 1 root root 2354 126 13:02 /etc/passwd
[root@qianshuiliyu ~]# vim  /etc/passwd
[root@qianshuiliyu ~]# ll -i /etc/passwd
17666143 -rw-r--r-- 1 root root 2358 22 18:13 /etc/passwd

8inode用完了,有空间但创建不了文件怎么办

1、删除一些文件释放一部分inode(做好备份)
2、添加一个分区挂载上去
硬盘在格式化的时候可以指定inode大小

ot@qianshuiliyu ~]# mkfs.ext4 -i 520000 /dev/sdb1 
mke2fs 1.42.9 (28-Dec-2013)
文件系统标签=
OS type: Linux
块大小=4096 (log=2)
分块大小=4096 (log=2)
Stride=0 blocks, Stripe width=0 blocks
10880 inodes, 1310720 blocks
65536 blocks (5.00%) reserved for the super user
第一个数据块=0
Maximum filesystem blocks=1342177280
40 block groups
32768 blocks per group, 32768 fragments per group
272 inodes per group
Superblock backups stored on blocks: 
	32768, 98304, 163840, 229376, 294912, 819200, 884736

Allocating group tables: 完成                            
正在写入inode表: 完成                            
Creating journal (32768 blocks): 完成
Writing superblocks and filesystem accounting information: 完成 

语法:[-i bytes-per-inode]/ [-I inode-size]

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

浅水鲤鱼

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值