磁盘为系统提供了最基本的持久化存储。

  文件系统则在磁盘的基础上,提供了一个用来管理文件的树状结构。

文件系统:索引节点和目录项

  文件系统是对存储设备上的文件,进行组织管理的机制。组织方式不同,就会形成不同的文件系统

  在 Linux 中一切皆文件,不仅普通的文件和目录,就连块设备、套接字、管道等,也都要通过统一的文件系统来管理。

  Linux 文件系统为每个文件都分配两个数据结构,索引节点(index node)和目录项(directory entry),分别记录文件的元信息和目录结构。

  • 索引节点,简称为 inode,用来记录文件的元数据,比如 inode 编号、文件大小、访问权限、修改日期、数据的位置等。索引节点和文件一一对应,它跟文件内容一样,都会被持久化存储到磁盘中。所以记住,索引节点同样占用磁盘空间。
  • 目录项,简称为 dentry,用来记录文件的名字、索引节点指针以及与其他目录项的关联关系。多个关联的目录项,就构成了文件系统的目录结构。不过,不同于索引节点,目录项是由内核维护的一个内存数据结构,所以通常也被叫做目录项缓存。

  索引节点是每个文件的唯一标志,而目录项维护的正是文件系统的树状结构,并且多个目录项可以对应一个索引节点,如:硬链接创建的是目录项,但索引节点不变。文件内容会缓存到 Page Cache 中。

  磁盘读写的最小单位是 512B 的扇区,读写这么小的单位,效率会很低。因此,文件系统把连续的 8 个扇区组成 1 个 4KB 大小的逻辑块,每次以该最小单元管理数据。

  Linux 文件系统的四大基本要素:目录项、索引节点、逻辑块、超级块。

虚拟文件系统

  为了支持各种不同的文件系统,Linux 内核在用户进程和文件系统的中间,又引入了一个抽象层:虚拟文件系统 VFS(Virtual File System),定义了一组所有文件系统都支持的数据结构和标准接口。用户进程只需要跟 VFS 提供的统一接口交互,就能和内核中的其他子系统交互,而不需要再关心底层各种文件系统的实现细节。

  文件系统分类,按照存储位置的不同可分为三类,并且要先挂载到 VFS 目录树中的某个子目录(称为挂载点),然后才能访问其中的文件:

  • 基于磁盘的文件系统,把数据直接存储在计算机本地挂载的磁盘中:Ext4、XFS、OverlayFS 。
  • 基于内存的文件系统,不需要磁盘空间,但会占用内存: /proc 、/sys 文件系统。
  • 基于网络的文件系统,用来访问其他计算机数据的文件系统:NFS、SMB、iSCSI 。

文件系统 I/O

  VFS 提供了一组标准的文件访问接口,这些接口以系统调用的方式,提供给应用程序使用。如:

  1. int open(const char *pathname, int flags, mode_t mode);
  2. ssize_t read(int fd, void *buf, size_t count);
  3. ssize_t write(int fd, const void *buf, size_t count);

文件读写方式

  • 1)缓冲与非缓冲 I/O:缓冲指的是标准库内部实现的缓存

    • 缓冲 I/O,是指利用标准库缓存来加速文件的访问,而标准库内部再通过系统调度访问文件。
    • 非缓冲 I/O,是指直接通过系统调用来访问文件,不再经过标准库缓存。
  • 2)直接与非直接 I/O:O_DIRECT 标志,本质上都是和文件系统交互,但有别于裸 I/O(跳过文件系统读写磁盘)
    • 直接 I/O,是指跳过操作系统的页缓存,直接跟文件系统交互来访问文件。
    • 非直接 I/O,是先要经过系统的页缓存,然后再由内核或额外的系统调用,真正写入磁盘。
  • 3)阻塞与非阻塞 I/O:O_NONBLOCK 标志,根据应用程序是否阻塞自身运行
    • 阻塞 I/O,是指应用程序执行 I/O 操作后,如果没有获得响应,就会阻塞当前线程,自然就不能执行其他任务。
    • 非阻塞 I/O,是指应用程序执行 I/O 操作后,不会阻塞当前的线程,可以继续执行其他的任务,随后再通过轮询或者事件通知的形式,获取调用的结果。select/poll 配合使用。
  • 4)同步与异步 I/O:O_SYNC 标志、O_DSYNC 标志,根据是否等待响应结果
    • 同步 I/O,是指应用程序执行 I/O 操作后,要一直等到整个 I/O 完成后,才能获得 I/O 响应。
    • 异步 I/O,是指应用程序执行 I/O 操作后,不用等待完成和完成后的响应,而是继续执行就可以。等到这次 I/O 完成后,响应会用事件通知的方式,告诉应用程序。
    • O_DSYNC,表示要等文件数据写入磁盘后,才能返回;而 O_SYNC,则是在 O_DSYNC 基础上,要求文件元数据也要写入磁盘后,才能返回。
    • O_ASYNC,异步 I/O,当访问管道或者网络套接字时,内核会再通过 SIGIO 或者 SIGPOLL,来通知进程文件是否可读写。
    • 阻塞/非阻塞 和 同步/异步 区别,其实就是两个不同角度的 I/O 划分方式。它们描述的对象也不同,阻塞 / 非阻塞针对的是 I/O 调用者(即应用程序),而同步 / 异步针对的是 I/O 执行者(即系统)。

查看容量

  df 命令,能查看文件系统的磁盘空间使用情况。但有时,你明明碰到空间不足的问题,可是用 df 查看磁盘空间后,却发现剩余空间还有很多。那是因为,除了文件数据,索引节点也占用磁盘空间,索引节点 Inode 的容量在格式化磁盘时是设定好的,空间不足是过多小文件导致的。

  1. $ df -h /dev/sda1
  2. Filesystem Size Used Avail Use% Mounted on
  3. /dev/sda1 29G 3.1G 26G 11% /
  4. $ df -i /dev/sda1
  5. Filesystem Inodes IUsed IFree IUse% Mounted on
  6. /dev/sda1 3870720 157460 3713260 5% /

查看缓存

  free 输出的 Cache,是页缓存和可回收 Slab 缓存的和,你可以从 /proc/meminfo ,直接得到它们的大小:

  1. $ cat /proc/meminfo | grep -E "SReclaimable|Cached"
  2. Cached: 748316 kB
  3. SwapCached: 0 kB
  4. SReclaimable: 179508 kB

  文件系统中的目录项和索引节点缓存

  内核使用 Slab 机制,管理目录项和索引节点的缓存。/proc/meminfo 只给出了 Slab 的整体大小,具体到每一种 Slab 缓存,还要查看 /proc/slabinfo 这个文件,或使用 slabtop :

  1. $ cat /proc/slabinfo | grep -E '^#|dentry|inode'
  2. # name <active_objs> <num_objs> <objsize> <objperslab> <pagesperslab> : tunables <limit> <batchcount> <sharedfactor> : slabdata <active_slabs> <num_slabs> <sharedavail>
  3. xfs_inode 0 0 960 17 4 : tunables 0 0 0 : slabdata 0 0 0
  4. ...
  5. ext4_inode_cache 32104 34590 1088 15 4 : tunables 0 0 0 : slabdata 2306 2306 0hugetlbfs_inode_cache 13 13 624 13 2 : tunables 0 0 0 : slabdata 1 1 0
  6. sock_inode_cache 1190 1242 704 23 4 : tunables 0 0 0 : slabdata 54 54 0
  7. shmem_inode_cache 1622 2139 712 23 4 : tunables 0 0 0 : slabdata 93 93 0
  8. proc_inode_cache 3560 4080 680 12 2 : tunables 0 0 0 : slabdata 340 340 0
  9. inode_cache 25172 25818 608 13 2 : tunables 0 0 0 : slabdata 1986 1986 0
  10. dentry 76050 121296 192 21 1 : tunables 0 0 0 : slabdata 5776 5776 0
  11. $ slabtop # 按下 c 按照缓存大小排序,按下 a 按照活跃对象数排序
  12. Active / Total Objects (% used) : 277970 / 358914 (77.4%)
  13. Active / Total Slabs (% used) : 12414 / 12414 (100.0%)
  14. Active / Total Caches (% used) : 83 / 135 (61.5%)
  15. Active / Total Size (% used) : 57816.88K / 73307.70K (78.9%)
  16. Minimum / Average / Maximum Object : 0.01K / 0.20K / 22.88K
  17. OBJS ACTIVE USE OBJ SIZE SLABS OBJ/SLAB CACHE SIZE NAME
  18. 69804 23094 0% 0.19K 3324 21 13296K dentry
  19. 16380 15854 0% 0.59K 1260 13 10080K inode_cache
  20. 58260 55397 0% 0.13K 1942 30 7768K kernfs_node_cache
  21. 485 413 0% 5.69K 97 5 3104K task_struct
  22. 1472 1397 0% 2.00K 92 16 2944K kmalloc-2048

Linux性能优化从入门到实战:14 文件系统篇:Linux 文件系统基础的更多相关文章

  1. Linux性能优化从入门到实战:01 Linux性能优化学习路线

      我通过阅读各种相关书籍,从操作系统原理.到 Linux内核,再到硬件驱动程序等等.   把观察到的性能问题跟系统原理关联起来,特别是把系统从应用程序.库函数.系统调用.再到内核和硬件等不同的层级贯 ...

  2. Linux性能优化从入门到实战:07 CPU篇:CPU性能优化方法

    性能优化方法论   动手优化性能之前,需要明确以下三个问题:   (1)如何评估性能优化的效果? 确定性能的量化指标.测试优化前的性能指标.测试优化后的性能指标.   量化指标的选择.至少要从应用程序 ...

  3. Linux性能优化从入门到实战:16 文件系统篇:总结磁盘I/O指标/工具、问题定位和调优

    (1)磁盘 I/O 性能指标 文件系统和磁盘 I/O 指标对应的工具 文件系统和磁盘 I/O 工具对应的指标 (2)磁盘 I/O 问题定位分析思路 (3)I/O 性能优化思路 Step 1:首先采用 ...

  4. Linux性能优化从入门到实战:09 内存篇:Buffer和Cache

      Buffer 是缓冲区,而 Cache 是缓存,两者都是数据在内存中的临时存储.   避免跟文中的"缓存"一词混淆,而文中的"缓存",则通指内存中的临时存储 ...

  5. Linux性能优化从入门到实战:15 文件系统篇:磁盘 I/O

    磁盘   磁盘是可以持久化存储的设备,按照存储介质来分类:   (1)机械磁盘(硬盘驱动器,Hard Disk Driver,HDD),主要由盘片和读写磁头组成,数据就存储在盘片的环状磁道中.在读写数 ...

  6. Linux性能优化从入门到实战:17 网络篇:网络基础

    网络模型 为了解决网络互联中异构设备的兼容性问题,并解耦复杂的网络包处理流程,国际标准化组织制定了开放式系统互联通信参考模型(Open System Interconnection Reference ...

  7. Linux性能优化从入门到实战:04 CPU篇:CPU使用率

      CPU使用率是单位时间内CPU使用情况的统计,以百分比方式展示. $ top top - 11:46:45 up 7 days, 11:52, 1 user, load average: 0.00 ...

  8. Linux性能优化从入门到实战:10 内存篇:如何利用Buffer和Cache优化程序的运行效率?

    缓存命中率   缓存命中率,是指直接通过缓存获取数据的请求次数,占所有数据请求次数的百分比,可以衡量缓存使用的好坏.命中率越高,表示使用缓存带来的收益越高,应用程序的性能也就越好.   实际上,缓存是 ...

  9. Linux性能优化从入门到实战:03 CPU篇:CPU上下文切换

      linux操作系统是将CPU轮流分配给任务,分时执行的.而每次执行任务时,CPU需要知道CPU寄存器(CPU内置的内存)和程序计数器PC(CPU正在执行指令和下一条指令的位置)值,这些值是CPU执 ...

随机推荐

  1. java导入ldif文件

    网上导入ldif文件的方式都是基于命令,或者相应工具如LDAP Browser \Editor v2.8.2. 但用java去实现这样的功能好像网上很少,于是我参照相应的开源代码并整理了一下,亲自测试 ...

  2. [HDU6403]:Card Game(dfs+DP+基环树)

    题目传送门 题目描述 她依然在我不知道的地方做我不知道的事.桌面上摊开着一些卡牌,这是她平时很爱玩的一个游戏.如今卡牌还在,她却不在我身边.不知不觉,我翻开了卡牌,回忆起了当时一起玩卡牌的那段时间.每 ...

  3. multipages-generator今日发布?!妈妈再也不用担心移动端h5网站搭建了!

    本文适合的读者?‍?‍?‍? 现在在手淘,京东,今日头条,美柚等过亿用户的手机app中的,都常见h5网页,他们有更新快,灵活,便于分享和传播的特性.这里有他们中的几个h5的例子:(手淘,美柚).这些a ...

  4. View 层

    package com.test.mvp.mvpdemo.mvp.v1.view; import android.app.ProgressDialog;import android.os.Bundle ...

  5. centos6.X mysql 5.1 主主配置

    1.配置文件 A库的配置文件: 在 /etc/my.cnf [mysqld] 段 新增: server_id= # log_bin 日志路径.格式以及删除时间(30天) log_bin=/var/li ...

  6. Java实体类之间的映射(多对多关系)

    多对对的映射,可以用学生和课程进行演示.一个学生可以选择多个课程,一个课程又对应了多个学生 定义学生类 class Stu{ private String name; private String n ...

  7. VMware vSphere 虚拟化简介

    目录 目录 vSphere 简介 vSphere 提供的工具 vCenter vCenter 的功能 vCenter 管理界面上提供的操作功能 HOST CLUSTER TEMPLATE Virtua ...

  8. 初窥AST

    一个简单的AST示例: AST结构: 里面有program.name.loc.type.comments.tokens 先看program: 重点关注program里面的body这个数组: JS引擎中 ...

  9. Java各类型占字节数

    byte 1字节short 2字节int 4字节long 8字节float 4字节double 8字节char 2字节boolean 1字节 其中,换算关系: 1GB=1024MB 1MB=1024K ...

  10. 把数据库中的数据制作成Excel数据

    把数据库中的数据制作成Excel数据 如果我们在使用Excel的时候,需要把数据库中的数据制作成Excel数据透视表,我们该怎么操作呢?如果数据在数据库中,我们不用把数据导入到工作表中,我们可以直接以 ...