第3章(1) Linux内核相关概念
Linux内核的组成
1. Linux内核源代码的目录结构
- arch:包含和硬件体系结构相关的代码,每种平台占一个相应的目录,如 i386、arm、
arm64、powerpc、mips 等。Linux 内核目前已经支持30 种左右的体系结构。在arch
目录下,存放的是各个平台以及各个平台的芯片对Linux 内核进程调度、内存管理、
中断等的支持,以及每个具体的SoC 和电路板的板级支持代码。 - block:块设备驱动程序 I/O 调度。
- crypto:常用加密和散列算法(如 AES、SHA 等),还有一些压缩和 CRC 校验算法。
- documentation:内核各部分的通用解释和注释。
- drivers :设备驱动程序,每个不同的驱动占用一个子目录,如 char、block、net、
mtd、i2c 等。 - fs:所支持的各种文件系统,如 EXT、FAT、NTFS、JFFS2 等。
- include:头文件,与系统相关的头文件放置在 include/linux 子目录下。
- init:内核初始化代码。著名的 start_kernel() 就位于 init/main.c 文件中。
- ipc:进程间通信的代码。
- kernel :内核最核心的部分,包括进程调度、定时器等,而和平台相关的一部分代码
放在arch/*/kernel 目录下。 - lib:库文件代码。
- mm:内存管理代码,和平台相关的一部分代码放在 arch/*/mm 目录下。
- net:网络相关代码,实现各种常见的网络协议。
- scripts:用于配置内核的脚本文件。
- security:主要是一个 SELinux 的模块。
- sound:ALSA、OSS 音频设备的驱动核心代码和常用设备驱动。
- usr:实现用于打包和压缩的 cpio 等。
- include:内核 API 级别头文件。
2. Linux内核的组成部分
Linux内核主要由进程调度(SCHED)、内存管理(MM)、虚拟文件系统(VFS)、网络接口(NET)、和进程间通信(IPC) 五个子系统组成。Linux内核的组成部分与关系图如下:

- 进程调度和内存管理:这两个子系统相互依赖,因为程序运行必须创建进程,而创建进程的第一步就是将程序和数据装入内存。
- 进程间通信和内存管理:进程间通信依赖内存管理提供共享内存通信机制。
- 虚拟文件系统和网络接口:虚拟文件系统依赖网络接口支持网络文件系统(NFS)。
- 虚拟文件系统和内存管理:虚拟文件系统利用内存管理支持RAMDISk设备;内存管理利用虚拟文件系统支持交换。
2.1 进程调度
用于控制系统中多个进程对CPU的访问。内核中其他子系统都依赖于系统调度来实现挂起或恢复进程。进程状态转换图如下:

- R (TASK_RUNNING),可执行状态&运行状态(在run_queue队列里的状态)
- S (TASK_INTERRUPTIBLE),可中断的睡眠状态, 可处理signal
- D (TASK_UNINTERRUPTIBLE),不可中断的睡眠状态, 可处理signal, 有延迟
- T (TASK_STOPPED or TASK_TRACED),暂停状态或跟踪状态, 不可处理signal, 因为根本没有时间片运行代码
- Z (TASK_DEAD - EXIT_ZOMBIE),退出状态,进程成为僵尸进程。不可被kill, 即不响应任务信号, 无法用SIGKILL杀死
- X (TASK_DEAD - EXIT_DEAD),退出状态,进程即将被销毁
2.2 内存管理
主要作用是控制多个进程安全地共享主内存区域。当CPU提供内存管理单元(MMU)时,Linux内存管理对于每个进程完成从虚拟内存到物理内存的转换。
2.3 虚拟文件系统
Linux虚拟文件系统隐藏了各种硬件的具体细节,并未所有设备提供了统一的接口。并且,虚拟文件系统独立于具体的文件系统,是对各种文件系统的一个抽象。
2.4 网络接口
网络接口提供对网络标准的存取和网络硬件的支持。
Linux中网络接口可分为:
- 网络协议:负责实现网络传输协议
- 网络驱动程序:负责与硬件设备通信
2.5 进程间通信
Linux支持的进程间通信机制有:信号量、共享内存、消息队列、管道、UNIX域套接字等,这些机制协助多进程、多自资源的互斥访问、进程间的同步和消息传递。
3. Linux内核空间与用户空间
Linux只能通过系统调用和硬件中断完成从用户空间到内核空间的控制转移。
第3章(1) Linux内核相关概念的更多相关文章
- 《LINUX内核设计与实现》第三周读书笔记——第一二章
<Linux内核设计与实现>读书笔记--第一二章 20135301张忻 估算学习时间:共2小时 读书:1.5 代码:0 作业:0 博客:0.5 实际学习时间:共2.5小时 读书:2.0 代 ...
- linux内核设计与实现一书阅读整理 之第一二章整合
第一章:Linux内核简介 一.Unix和linux Unix是一个强大.健壮和稳定的操作系统. 1.Unix内核特点 十分简洁:仅提供几百个系统调用并且有明确的目的: 在Unix中,大部分东西都被( ...
- Linux 内核 链表 的简单模拟(2)
接上一篇Linux 内核 链表 的简单模拟(1) 第五章:Linux内核链表的遍历 /** * list_for_each - iterate over a list * @pos: the & ...
- Linux 内核 链表 的简单模拟(1)
第零章:扯扯淡 出一个有意思的题目:用一个宏定义FIND求一个结构体struct里某个变量相对struc的编移量,如 struct student { int a; //FIND(struct stu ...
- Linux内核分析:期中总结
第一章:计算机是如何工作的 计算机大部分都是用冯诺依曼体系结构,即存储程序计算机. 两个层面: 1.硬件: cpu(IP寄存器:指针,指向内存的某块区域)——总线——内存(代码与数据) 2.程序员: ...
- Linux内核分析期中知识点总结
Linux内核分析期中知识点总结 1. 计算机是如何工作的 存储程序计算机工作模型:冯诺依曼体系结构 X86汇编基础 会变一个简单的C程序分析其汇编指令执行过程 2. 操作系统是如何工作的 函数调用堆 ...
- 20169211《Linux内核原理与分析》第二周作业
<linux内核分析>实验一实验报告 <linux内核设计与实现>第1.2.18章学习总结 一.<linux内核分析>实验一实验报告 在进行实验楼操作 ...
- 2017-2018-1 20179215《Linux内核原理与分析》第十周作业
第17章 设备与模块 一.设备类型 除了以上3种典型的设备之外,其实Linux中还有一些其他的设备类型,其中见的较多的应该算是"伪设备".所谓"伪设备",其实 ...
- 《Linux内核设计与实现》第四章学习笔记
<Linux内核设计与实现>第四章学习笔记 ——进程调度 姓名:王玮怡 学号:20135116 一.多任务 1.多任务操作系统的含义 多任务操作系统就是能同时并发地交 ...
随机推荐
- nexus 私服 低配置服务器启动不能访问的问题
1核1G的渣渣服务器启动无法访问. 请更换更高配置的服务器.
- soap get/post请求
pom.xml依赖: <dependency> <groupId>org.apache.httpcomponents</groupId> <artifactI ...
- NetCore+AutoMapper多个对象映射到一个Dto对象
目录 一. 定义源映射类和被映射类DTO二.注入AutoMapper三.配置映射四.写测试 一.定义源映射对象 为了体现AutoMapper映射特性,在SocialAttribute中的Name属性没 ...
- tomcat 中无法添加项目等问题的解决方案
博客地址:http://www.moonxy.com 一.前言 今天新建了一个 maven 项目,添加程序文件之后,发现无法添加项目,然后修改配置,将应用添加到了 tomcat,启动时又报错,解决出现 ...
- php接受的post数据类型
通常情况下用户使用浏览器网页表单向服务器post提交数据,我们使用PHP的$_POST接收用户POST到服务器的数据,并进行适当的处理.但有些情况下,如用户使用客户端软件向服务端php程序发送post ...
- java中String常见问题
java中String常见问题 1.字符串比较==和equals ==:比较的是对象,判断两个引用的是否为同一内存地址(物理对象) equals:比较的是值 2.通过空白字符拆封字符串 str.spi ...
- Rsync 服务部署与参数详解
Rsync 简介 rsync 是一款开源的.快速的.多功能的.可实现全量及增量的本地或远程数据同步备份的优秀工具.Rsync软件适用于unix/linux/windows等多种操作系统平台. 传统的 ...
- C++虚函数表和对象存储
C++虚函数表和对象存储 C++中的虚函数实现了多态的机制,也就是用父类型指针指向其子类的实例,然后通过父类的指针调用实际子类的成员函数,这种技术可以让父类的指针有"多种形态",这 ...
- 单元测试框架Uinttest一文详解
一谈及unittest,大家都知道,unittest是Python中自带的单元测试框架,它里面封装好了一些校验返回的结果方法和一些用例执行前的初始化操作.unittest单元测试框架不仅可以适用于单元 ...
- 从零开始入门 K8s | 应用配置管理
一.需求来源 背景问题 首先一起来看一下需求来源.大家应该都有过这样的经验,就是用一个容器镜像来启动一个 container.要启动这个容器,其实有很多需要配套的问题待解决: 第一,比如说一些可变的配 ...