🔥作者简介: 一个平凡而乐于分享的小比特,中南民族大学通信工程专业研究生,研究方向无线联邦学习 🎬擅长领域:驱动开发,嵌入式软件开发,BSP开发 ❄️作者主页:一个平凡而乐于分享的小比特的个人主页 ✨收录专栏:操作系统,本专栏为讲解各操作系统的历史脉络,以及各性能对比,以及内部工作机制,方便开发选择 欢迎大家点赞 👍 收藏 ⭐ 加关注哦!💖💖

Linux 内核将所有系统资源抽象为文件,无论是:
所有操作都通过统一的文件描述符(File Descriptor)接口完成。
系统资源 | 文件类比 | 操作方式 |
|---|---|---|
硬盘文件 | 图书馆的书籍 | 通过书号(fd)借阅/归还 |
键盘输入 | 借书窗口 | 通过窗口号读取输入 |
显示器 | 还书窗口 | 通过窗口号输出内容 |
打印机 | 复印机 | 通过设备号发送打印任务 |
网络连接 | 馆际互借通道 | 通过通道号收发数据 |
// 所有设备操作都使用相同API
int fd = open("/dev/keyboard", O_RDONLY); // 打开键盘
read(fd, buffer, size); // 读取键盘输入
close(fd); // 关闭设备
int file_fd = open("document.txt", O_RDWR); // 打开文件
read(file_fd, buffer, size); // 读取文件特性 | 传统系统 | Linux“一切皆文件” |
|---|---|---|
接口统一性 | 每个设备不同API | 统一open/read/write/close |
学习成本 | 高(需学多个API) | 低(一套API通吃) |
编程复杂度 | 复杂 | 简单直观 |
扩展性 | 困难 | 容易(新增设备也走文件接口) |
场景示例:写日志程序
// 向文件、终端、网络同时输出日志,使用相同代码
write(file_fd, log_msg, len); // 写文件
write(terminal_fd, log_msg, len); // 显示在终端
write(socket_fd, log_msg, len); // 发送到网络想象一个国际旅行转换插头:
VFS就是内核的“转换插头”:
应用程序 → open()/read()/write() → VFS统一接口
↓
EXT4 NTFS FAT32 /proc /dev socket
↓ ↓ ↓ ↓ ↓ ↓
磁盘文件 进程信息 硬件设备 网络连接应用层
↓
系统调用层(open/read/write/close)
↓
VFS抽象层(统一文件模型)
│
├── 文件操作(file_operations)
├── 索引节点(inode) - 文件的身份证
├── 目录项(dentry) - 文件的路径信息
└── 超级块(super_block) - 文件系统信息
↓
具体文件系统层(EXT4、FAT32、NFS等)
↓
设备驱动层(硬盘、U盘、网络设备)struct inode { // 文件的唯一标识(身份证)
unsigned long i_ino; // 索引号
umode_t i_mode; // 文件类型和权限
struct file_operations *i_fop; // 文件操作函数表
};
struct file { // 打开文件的实例(借书证)
struct path f_path; // 文件路径
loff_t f_pos; // 当前读写位置
struct file_operations *f_op; // 操作函数
};
struct file_operations { // 操作函数表(说明书)
ssize_t (*read)(struct file *, char __user *, size_t, loff_t *);
ssize_t (*write)(struct file *, const char __user *, size_t, loff_t *);
int (*open)(struct inode *, struct file *);
int (*release)(struct inode *, struct file *);
};// 应用程序调用
int fd = open("/home/user/data.txt", O_RDONLY);
// 内核中的处理流程:
1. VFS接收open系统调用
2. 解析路径"/home/user/data.txt"
3. 查找dentry缓存(路径缓存)
4. 找到对应的inode(文件信息)
5. 调用具体文件系统的open函数(EXT4的open)
6. 创建file结构体(打开的文件实例)
7. 分配文件描述符fd
8. 返回fd给应用程序┌─────────────────────────────────────┐
│ 用户空间(User Space) │
│ ┌─────────────────────────────┐ │
│ │ 应用程序(APP1、APP2...) │ │
│ └─────────────────────────────┘ │
├─────────────────────────────────────┤ ← 系统调用边界
│ 内核空间(Kernel Space) │
│ ┌─────────────────────────────┐ │
│ │ 系统调用接口(SYSCALL) │ ← 第一层:接口层
│ ├─────────────────────────────┤ │
│ │ 进程/内存/文件子系统 │ ← 第二层:核心管理层
│ ├─────────────────────────────┤ │
│ │ 虚拟文件系统(VFS) │ ← 第三层:抽象适配层
│ ├─────────────────────────────┤ │
│ │ 具体文件系统(EXT4/NTFS...) │ ← 第四层:实现层
│ ├─────────────────────────────┤ │
│ │ 设备驱动层(驱动1、驱动2...) │ ← 第五层:硬件交互层
│ └─────────────────────────────┘ │
└─────────────────────────────────────┘作用:用户程序进入内核的唯一大门
类比:银行柜台窗口
示例:
用户程序:我要取钱(系统调用)
柜台窗口:好的,请提供凭证(参数检查)
内部处理:金库操作(内核处理)
返回结果:这是您的钱(返回数据)// 三大核心管理器
1. 进程管理器:
- 负责进程创建、调度、销毁
- 类比:机场塔台调度飞机
2. 内存管理器:
- 虚拟内存管理
- 物理内存分配
- 类比:酒店房客管理系统
3. 文件系统管理器:
- 文件操作管理
- 权限控制
- 类比:图书馆管理系统文件系统 | 用途 | 特点 |
|---|---|---|
EXT4 | 常规磁盘 | 日志、大文件支持 |
FAT32 | U盘、移动设备 | 跨平台兼容 |
NTFS | Windows兼容 | 支持ACL权限 |
/proc | 进程信息 | 虚拟文件系统 |
tmpfs | 内存文件 | 高速临时存储 |
// 驱动架构示例:块设备驱动
struct block_device_operations {
int (*open)(struct block_device *, fmode_t);
void (*release)(struct gendisk *, fmode_t);
int (*ioctl)(struct block_device *, fmode_t, unsigned, unsigned long);
int (*media_changed)(struct gendisk *);
};
// 注册驱动:告诉内核"我会处理这种设备"
register_blkdev(MAJOR_NUM, "my_disk_driver");开发角色 | 关注层 | 工作内容 | 不需要关心 |
|---|---|---|---|
应用开发者 | 用户空间 | 业务逻辑 | 底层实现 |
内核开发者 | 核心子系统 | 算法优化 | 硬件差异 |
文件系统开发者 | VFS+具体FS | 文件系统实现 | 硬件驱动 |
驱动开发者 | 设备驱动层 | 硬件控制 | 上层业务 |
用户点击"保存文档"(用户空间)
↓
应用调用write()系统调用(系统调用层)
↓
VFS接收请求,查找文件操作表(VFS层)
↓
EXT4文件系统处理写操作(文件系统层)
↓
块设备层将数据组织成块(块设备层)
↓
SATA驱动控制硬盘写入(设备驱动层)
↓
硬盘物理写入数据(硬件层)
↓
逐层返回成功状态用户程序:wget http://example.com/file.txt
第1步:创建网络连接
socket() → VFS → 网络文件系统 → TCP/IP协议栈 → 网卡驱动
第2步:接收数据
read(网络fd) → VFS → 网络层 → 从网卡读取数据
第3步:写入本地文件
write(文件fd) → VFS → EXT4 → 块设备层 → 硬盘驱动 → 物理写入
第4步:更新文件属性
fstat() → VFS → EXT4 → 更新inode信息设计原则 | 解决的问题 | 实现方式 | 带来的好处 |
|---|---|---|---|
一切皆文件 | 设备接口杂乱 | 统一文件描述符 | 编程简单,接口一致 |
VFS抽象层 | 文件系统差异 | 虚拟文件系统接口 | 支持多文件系统,应用透明 |
分层设计 | 系统复杂度高 | 清晰层次划分 | 易于开发、调试、维护 |
这种设计让Linux能够:
最后记住这个核心比喻:
Linux内核就像一个高度组织的快递公司