探究linux内核,超详细解析子系统

合集下载

Linux操作系统的内核设计分析

Linux操作系统的内核设计分析

Linux操作系统的内核设计分析Linux操作系统作为开源操作系统的代表,已经在各个领域得到了广泛应用。

而Linux操作系统的内核则是这个系统之所以能够运转的关键所在。

本文将就Linux操作系统的内核设计进行分析,并探讨其优劣之处。

一、Linux内核设计的基础Linux内核的设计基础主要包括以下几个方面:1. 开放源码Linux内核采用的是GPL协议,这意味着它是一个开放源码的项目。

这为世界各地的开发人员提供了极大的便利,方便他们进行开发和修改。

同时,这也确保了Linux内核的透明度,并且鼓励开发者贡献代码的同时,深度参与到Linux开源社区的构建和升级中。

2. 模块化Linux内核的构造采用的是模块化设计。

这种设计方式将内核代码分成独立的模块,每个模块都可以独立编译、加载和卸载。

采用模块化的设计,能够使得开发人员能够更加细致地打包、编译、并部署只包含他们需要的模块的系统。

3. 多任务Linux内核是一个基于多任务设计的系统。

这意味着它能够使得多个程序同时运行,并能够平滑高效地进行任务的切换。

这给开发人员提供了各种各样的自由,使得他们能够更加高效地进行开发。

4. 支持众多处理器架构Linux内核的支持范围非常广泛,它可以适配众多处理器架构。

这意味着一个制造商可以使用不同的处理器架构去生产设备,并且这些设备都能够安装和运行Linux操作系统。

5. 外层调用接口Linux内核支持开放式的外层调用接口。

这使得用户层可以很容易地调用Linux 内核执行某个任务。

这些用户层应用包括网上购物网站、应用程序和各种驱动程序。

6. 子系统Linux内核的子系统主要包括进程管理、内存管理、I/O管理和网络管理等。

二、Linux内核的优点Linux内核具有以下主要优点:1. 开源性Linux内核本身是一个开源的、由社区驱动的项目。

这意味着在它的附加组件和周边产品中,广大的开发者社区都可以为用户提供帮助和支持。

2. 安全性相比其他闭源操作系统,Linux内核在安全性方面更具优势。

linux操作系统的结构及详细说明

linux操作系统的结构及详细说明

linux操作系统的结构及详细说明linux的操作系统的结构你了解多少呢?下面由店铺为大家整理了linux操作系统的结构及详细说明的相关知识,希望对大家有帮助!linux操作系统的结构及详细说明:一、 linux内核内核是操作系统的核心,具有很多最基本功能,它负责管理系统的进程、内存、设备驱动程序、文件和网络系统,决定着系统的性能和稳定性。

Linux 内核由如下几部分组成:内存管理、进程管理、设备驱动程序、文件系统和网络管理等。

系统调用接口:SCI 层提供了某些机制执行从用户空间到内核的函数调用。

这个接口依赖于体系结构,甚至在相同的处理器家族内也是如此。

SCI 实际上是一个非常有用的函数调用多路复用和多路分解服务。

在 ./linux/kernel 中您可以找到 SCI 的实现,并在 ./linux/arch 中找到依赖于体系结构的部分。

1. 内存管理对任何一台计算机而言,其内存以及其它资源都是有限的。

为了让有限的物理内存满足应用程序对内存的大需求量,Linux 采用了称为“虚拟内存”的内存管理方式。

Linux 将内存划分为容易处理的“内存页”(对于大部分体系结构来说都是 4KB)。

Linux 包括了管理可用内存的方式,以及物理和虚拟映射所使用的硬件机制。

不过内存管理要管理的可不止 4KB 缓冲区。

Linux 提供了对 4KB 缓冲区的抽象,例如 slab 分配器。

这种内存管理模式使用 4KB 缓冲区为基数,然后从中分配结构,并跟踪内存页使用情况,比如哪些内存页是满的,哪些页面没有完全使用,哪些页面为空。

这样就允许该模式根据系统需要来动态调整内存使用。

为了支持多个用户使用内存,有时会出现可用内存被消耗光的情况。

由于这个原因,页面可以移出内存并放入磁盘中。

这个过程称为交换,因为页面会被从内存交换到硬盘上。

内存管理的源代码可以在 ./linux/mm 中找到。

2 .进程管理进程实际是某特定应用程序的一个运行实体。

linux系统结构框架

linux系统结构框架

linux系统结构框架
Linux系统一般有4个主要部分:内核、shell、文件系统和应用程序。

内核、shell和文件系统一起形成了基本的操作系统结构,它们使得用户可以运行程序、管理文件并使用系统。

1.内核:内核是操作系统的核心,具有很多最基本功能,它负责管理系统的进程、内存、设备驱动程序、文件和网络系统,决定着系统的性能和稳定性。

Linux 内核由如下几部分组成:内存管理、进程管理、设备驱动程序、文件系统和网络管理等。

2.Shell:shell是命令行解释器,可以为用户提供对系统的访问,也可以被用作程序或者脚本的命令行环境。

有多种shell可以选择,比如bash,zsh,ksh等。

3.文件系统:Linux系统使用一个基于文件的层级结构来组织和存储系统资源。

每个文件和目录都从根目录“/”开始,然后层层嵌套。

4.应用程序:Linux系统上可以运行各种应用程序,包括文本编辑器、浏览器、开发工具等。

应用程序为用户提供了使用系统的接口。

在更细致的层次结构上,Linux系统的内存管理分为几个主要组件,包括物理内存管理、虚拟内存管理以及内核内存管理等。

物理内存管理负责物理内存的分配和回收,虚拟内存管理则将物理内存映射到虚拟地址空间,并实现内存的共享和保护。

内核内存管理则负责内核空间的分配和释放,以及内核页面的交换等。

linux分层设计体系结构

linux分层设计体系结构

linux分层设计体系结构Linux是一种开源的操作系统,其设计采用了分层的体系结构。

这种设计使得Linux具有高度的灵活性和可扩展性,同时也方便了系统的维护和管理。

本文将详细介绍Linux的分层设计体系结构。

在Linux的分层设计中,最底层是硬件层。

硬件层包括计算机的各种硬件设备,如处理器、内存、硬盘、网络接口等。

Linux通过设备驱动程序来管理和控制这些硬件设备,使其能够与操作系统进行交互。

在硬件层之上是内核层。

内核是操作系统的核心,负责管理系统的资源和提供各种系统服务。

Linux的内核是一个单独的模块,可以独立于其他软件进行开发和维护。

内核提供了各种系统调用接口,以及对进程、文件系统、网络和设备的管理和控制功能。

在内核层之上是库层。

库是一组共享的代码和函数,可以为应用程序提供常用的功能和服务。

Linux提供了许多不同的库,如C库、数学库、网络库等。

这些库可以被开发人员用来开发应用程序,提高开发效率和代码复用性。

在库层之上是应用层。

应用层包括各种应用程序和工具,如文本编辑器、图形界面、网络浏览器等。

这些应用程序可以通过系统调用接口与内核进行交互,并利用库提供的功能来实现各种任务和操作。

除了以上四个层次外,Linux还有其他一些重要的组件和模块。

例如,系统初始化和启动过程中,会加载引导程序和初始化程序;文件系统是用来组织和管理文件和目录的;网络协议栈是用来实现网络通信的;系统服务是用来提供各种系统功能和服务的。

这些组件和模块与其他层次之间相互关联,共同构成了Linux的完整体系结构。

Linux的分层设计体系结构具有许多优点。

首先,分层设计使得系统的各个组件和模块之间相互独立,可以分别进行开发、测试和维护,提高了开发和维护效率。

其次,分层设计使得系统的各个层次之间的接口清晰明确,方便了系统的扩展和升级。

此外,分层设计还提高了系统的稳定性和可靠性,一旦某个层次出现问题,不会对其他层次造成影响。

Linux的分层设计体系结构是一种高效、灵活和可扩展的设计方式。

linux操作系统的基本原理

linux操作系统的基本原理

linux操作系统的基本原理
Linux操作系统是一种开源的自由操作系统,其基本原理包括以下几个方面:
1. 内核:Linux操作系统的核心是内核,它是操作系统的核心模块,控制着系统的所有硬件和软件资源。

内核具有多任务处理、进程管理、文件系统管理、设备管理、内存管理等功能。

2. 虚拟文件系统:Linux操作系统使用虚拟文件系统(VFS)作为文件系统的框架。

VFS为所有文件系统提供了一个通用的接口,使得文件系统可以互相转换。

3. Shell:Linux操作系统使用的命令行接口被称为Shell。

Shell是用户与内核交互的一种方式,用户可以通过Shell来执行命令、管理文件、创建进程等。

4. 程序库:Linux操作系统提供了一系列的程序库,如C库、X库等,这些程序库提供了一些基本的函数和工具,方便程序员开发应用程序。

5. 系统调用:Linux操作系统提供了大量的系统调用,它们是用户程序和内核之间的接口。

用户程序可以通过系统调用来访问内核提供的各种服务,如读写文件、创建进程、网络通信等。

Linux操作系统的基本原理为开发者和用户提供了一个稳定、高效、灵活的操作系统。

它的开源特性使得用户可以自由地修改和定制操作系统,满足不同需求。

- 1 -。

什么是Linux内核Linux内核体系结构

什么是Linux内核Linux内核体系结构

什么是Linux内核 Linux内核体系结构前言本文主要讲解什么是Linux内核,以及通过多张图片展示Linux内核的作用与功能,以便于读者能快速理解什么是Linux内核,能看懂Linux内核。

拥有超过1300万行的代码,Linux内核是世界上最大的开源项目之一,但是内核是什么,它用于什么?02什么是内核内核是与计算机硬件接口的易替换软件的最低级别。

它负责将所有以“用户模式”运行的应用程序连接到物理硬件,并允许称为服务器的进程使用进程间通信(IPC)彼此获取信息。

03内核还要分种类?是的,没错。

3.1 微内核微内核只管理它必须管理的东西:CPU、内存和IPC。

计算机中几乎所有的东西都可以被看作是一个附件,并且可以在用户模式下处理。

微内核具有可移植性的优势,因为只要操作系统仍然试图以相同的方式访问硬件,就不必担心您是否更改了视频卡,甚至是操作系统。

微内核对内存和安装空间的占用也非常小,而且它们往往更安全,因为只有特定的进程在用户模式下运行,而用户模式不具有管理员模式的高权限。

3.1.1 Pros可移植性安装占用空间小小内存占用安全3.1.2 Cons通过驱动程序,硬件更加抽象硬件可能反应较慢,因为驱动程序处于用户模式进程必须在队列中等待才能获得信息进程不能在不等待的情况下访问其他进程3.2 单内核单内核与微内核相反,因为它们不仅包含CPU、内存和IPC,而且还包含设备驱动程序、文件系统管理和系统服务器调用等内容。

单内核更擅长于访问硬件和多任务处理,因为如果一个程序需要从内存或运行中的其他进程中获取信息,那么它就有一条更直接的线路来访问信息,而不需要在队列中等待来完成任务。

但是,这可能会导致问题,因为在管理模式下运行的东西越多,如果行为不正常,就会有越多的东西导致系统崩溃。

3.2.1 Pros更直接地访问程序的硬件流程之间更容易通信如果支持您的设备,它应该不需要额外安装就可以工作进程反应更快,因为没有等待处理器时间的队列3.2.2 Cons较大安装体积较大内存占用不太安全,因为所有操作都在管理模式下运行04混合的内核混合内核能够选择在用户模式下运行什么,以及在管理模式下运行什么。

linux内核简介.ppt

API和系统调用完全不同:
–API只是一个函数定义 –系统调用通过“软中断”向内核发出一个明确
的请求
2020年2月10日
东华大学计算机科学与技术学院 by XinLuo
10
系统调用图解 用户态
内核态
系统调用 1
系统调用 返回
2
trap 0
2020年2月10日
东华大学计算机科学与技术学院 by XinLuo
中断的概念,终端 控制台设备驱动
Shell程序分析输入参 数,确定这是ls命令
什么是shell?
终端解释程序
什么是系统调用?
内核态用户态相关问 题,内存保护
调用系统调用fork生成 一个shell本身的拷贝
调用exec系统调用将ls 的可执行文件装入内存
从系统调用返回
Shell和ls都得以执行
系统调用是怎 么实现的?
3
Linux 基本概念
• 系统调用 • 内存管理 • 进程管理 • 虚拟文件系统(VFS) • 信号机制 • 内核初始化过程
2020年2月10日
东华大学计算机科学与技术学院 by XinLuo
4
➢ 提纲
• 用户态和内核态 • 系统调用意义 • 系统调用方法
2020年2月10日
东华大学计算机科学与技术学院 by XinLuo
Memory manager Signal 。。。
File systems Process management Device drivers Net work
Kernel interface to the hardware
Terminal controllers Terminals
Device controllers Memory controllers

linux系统工作原理

linux系统工作原理
Linux系统是一种开源的操作系统,它的工作原理可以分为以下几个方面:
1. 内核:Linux系统的核心是内核,它是操作系统的最底层,负责管理计算机的硬件资源,包括CPU、内存、输入输出设备等。

内核还负责管理进程、线程、文件系统等系统资源,同时提供了一些系统调用接口供上层应用程序使用。

2. Shell:Shell是用户与Linux系统交互的界面,它提供了一种命令行或图形界面的方式让用户与系统交互。

Shell还可以执行脚本,自动化执行一些操作。

3. 文件系统:Linux系统的文件系统是一个层次化的树形结构,根目录为/,其下有很多子目录和文件。

文件系统还提供了权限控制、链接等功能,保证了用户数据的安全和稳定性。

4. 进程管理:Linux系统采用了进程的方式管理系统资源,每个进程都有自己的独立空间,同时可以与其他进程通信。

Linux系统还支持多线程,提高了系统的并发处理能力。

5. 网络管理:Linux系统支持TCP/IP协议,可以实现网络通信。

Linux系统还提供了一些网络管理工具,如netstat、ping等,方便管理员进行网络管理和故障排除。

总之,Linux系统的工作原理是一个复杂的系统,它通过内核、Shell、文件系统、进程管理、网络管理等组成部分协同工作,为用户提供了一个高效稳定的操作系统环境。

linux操作系统的组成部分及功能

Linux操作系统的组成部分及功能如下:
1. 内核(Kernel):内核是Linux操作系统的核心,负责管理系统的软硬件资源。

它实现了进程调度、内存管理、中断处理、异常陷阱处理等功能,还负责进程管理、进程通信机制、虚拟内存管理、文件系统驱动以及USB、网络、声音等各类设备驱动子系统。

内核控制整个计算机的运行,提供相应的硬件驱动程序、网络接口程序,并管理所有应用程序的执行。

2. Shell:Shell是系统的用户界面,提供了用户与内核进行交互操作的一种接口。

它接收用户输入的命令并把它送入内核去执行。

3. 文件系统:Linux文件系统是文件存放在磁盘等存储设备上的组织方法,主要体现在对文件和目录的组织上。

4. 应用程序:Linux应用程序辅助用户完成一些特定的任务,例如文本编辑器、编程语言、基于X Window架构的图形桌面系统、办公套装软件、Internet工具以及数据库等。

总的来说,Linux操作系统由内核、Shell、文件系统和应用程序四个部分组成,各部分协同工作,使得Linux能够高效地运行和管理计算机资源。

linux操作系统的基本体系结构

linux操作系统的基本体系结构一、内核(Kernel)Linux操作系统的核心是内核,它负责管理系统资源、控制硬件设备、调度进程和提供基本的系统服务。

Linux内核采用单内核结构,包含了操作系统的大部分核心功能和驱动程序。

内核是操作系统的核心组件,它提供了操作系统运行所必须的基本功能。

Linux内核具有以下特点:1、多任务处理:Linux内核支持多任务处理,可以同时运行多个程序,并实现多个程序之间的切换和管理。

2、硬件管理:Linux内核负责管理硬件设备,与硬件设备交互,控制硬件设备的工作状态。

3、内存管理:Linux内核负责管理系统的内存,包括内存的分配、释放、映射和交换等操作。

4、文件系统:Linux内核支持多种文件系统,包括ext4、NTFS、FAT等,负责文件的读写、管理和保护。

5、进程管理:Linux内核管理系统进程,包括进程的创建、调度、挂起、唤醒和终止等操作。

6、网络通信:Linux内核支持网络通信功能,包括TCP/IP协议栈、网卡驱动等,实现网络数据传输和通信。

二、ShellShell是Linux操作系统的命令解释器,用户通过Shell与操作系统进行交互。

Shell接受用户的命令,并将其转换为对应的系统调用,最终由内核执行。

Linux系统中常用的Shell有Bash、Zsh等,用户可以根据自己的喜好选择不同的Shell。

Shell具有以下功能:1、命令解释:Shell接受用户输入的命令,并将其翻译为操作系统可以执行的命令。

2、执行程序:Shell可以执行各种程序、脚本和命令,包括系统工具、应用程序等。

3、环境控制:Shell可以设置环境变量、别名和路径等,帮助用户管理系统环境。

4、文件处理:Shell可以处理文件操作,包括创建、删除、复制、移动等。

5、脚本编程:Shell支持脚本编程,用户可以编写Shell脚本来自动执行一系列操作。

三、系统工具Linux操作系统提供了丰富的系统工具,帮助用户管理系统和执行各种任务。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

探究linux内核,超详细解析子系统Perface 前面已经写过一篇《嵌入式linux内核的五个子系统》,概括性比较强,也比较简略,现在对其进行补充说明。

仅留此笔记,待日后查看及补充!Linux内核的子系统内核是操作系统的核心。

Linux内核提供很多基本功能,如虚拟内存、多任务、共享库、需求加载、共享写时拷贝(Copy-On-Write)以及网络功能等。

增加各种不同功能导致内核代码不断增加。

Linux内核把不同功能分成不同的子系统的方法,通过一种整体的结构把各种功能集合在一起,提高了工作效率。

同时还提供动态加载模块的方式,为动态修改内核功能提供了灵活性。

系统调用接口用户程序通过软件中断后,调用系统内核提供的功能,这个在用户空间和内核提供的服务之间的接口称为系统调用。

系统调用是Linux内核提供的,用户空间无法直接使用系统调用。

在用户进程使用系统调用必须跨越应用程序和内核的界限。

Linux内核向用户提供了统一的系统调用接口,但是在不同处理器上系统调用的方法各不相同。

Linux内核提供了大量的系统调用,现在从系统调用的基本原理出发探究Linux系统调用的方法。

这是在一个用户进程中通过GNU C库进行的系统调用示意图,系统调用通过同一个入口点传入内核。

以i386体系结构为例,约定使用EAX寄存器标记系统调用。

当加载了系统C库调用的索引和参数时,就会调用0x80软件中断,它将执行system_call函数,这个函数按照EAX 寄存器内容的标示处理所有的系统调用。

经过几个单元测试,会使用EAX寄存器的内容的索引查system_call_table表得到系统调用的入口,然后执行系统调用。

从系统调用返回后,最终执行system_exit,并调用resume_userspace函数返回用户空间。

linux内核系统调用的核心是系统多路分解表。

最终通过EAX寄存器的系统调用标识和索引值从对应的系统调用表中查出对应系统调用的入口地址,然后执行系统调用。

linux系统调用并不单层的调用关系,有的系统调用会由内核进行多次分解,例如socket调用,所有socket相关的系统调用都与_NR_socketcall系统调用关联在一起,通过另外一个适当的参数获得适当的调用。

进程管理子系统当用户使用系统提供的库函数进行进程编程,用户可以动态地创建进程,进程之间还有等待,互斥等操作,这些操作都是由linux内核来实现的。

linux内核通过进程管理子系统实现了进程有关的操作,在linux系统上,所有的计算工作都是通过进程表现的,进程可以是短期的(执行一个命令),也可以是长期的(一种网络服务)。

linux系统是一种动态系统,通过进程管理能够适应不断变化的计算需求。

在用户空间,进程是由进程标示符(PID)表示的。

从用户角度看,一个PID是一个数字值,可以唯一标识一个进程,一个PID值在进程的整个生命周期中不会更改,但是PID可以在进程销毁后被重新使用。

创建进程可以使用几种方式,可以创建一个新的进程,也可以创建当前进程的子进程。

在linux内核空间,每个进程都有一个独立的数据结构,用来保存该进程的ID、优先级、地址的空间等信息,这个结构也被称做进程控制块(Process Control Block)。

所谓的进程管理就是对进程控制块的管理。

linux的进程是通过fork()函数系统调用产生的。

调用fork()的进程叫做父进程,生成的进程叫做子进程。

子进程被创建的时候,除了进程ID外,其它数据结构与父进程完全一致。

在fork()系统调用创建内存之后,子进程马上被加入内核的进程调试队列,然后使用exec()系统调用,把程序的代码加入到子进程的地址空间,之后子进程就开始执行自己的代码。

在一个系统上可以有多个进程,但是一般情况下只有一个CPU,在同一个时刻只能有一个进程在工作,即使有多个CPU,也不可能和进程的数量一样多。

如果让若干的进程都能在CPU上工作,这就是进程管理子系统的工作。

linux内核设计了存放进程队列的结构,在一个系统上会有若干队列,分别存放不同状态的进程。

一个进程可以有若干状态,具体是由操作系统来定义的,但是至少包含运行态、就绪态和等待3种状态,内核设计了对应的队列存放对应状态的进程控制块。

当一个用户进程被加载后,会进入就绪态,被加入到就绪态队列,CPU时间被轮转到就绪态队列后,切换到进程的代码,进程被执行,当进程的时间片到了以后被换出。

如果进程发生I/O操作也会被提前被换出,并且存放到等待队列,当I/O请求返回后,进程又被放入就绪队列。

linux系统对进程队列的管理设计了若干不同的方法,主要的目的是提高进程调试的稳定性。

内核管理子系统内存是计算机的重要资源,也是内核的的重要部分。

使用虚拟内存技术的计算机,内存管理的硬件按照分页方式管理内存。

分页方式是把计算机系统的物理内存按照相同大小等分,每个内存分片称作内存页,通常内存页大小是4KB。

Linux内核的内存管理子系统管理虚拟内存与物理内存之间的映射关系,以及系统可用内存空间。

内存管理要管理的不仅是4KB缓冲区。

Linux提供了对4KB缓冲区的抽象,例如slab分配器。

这种内存管理模式使用4KB缓冲区为基数,然后从中分配结构,并跟踪内存页使用情况,比如哪些内存页是满的,哪些页面没有完全使用,哪些页面为空。

这样就允许该模式根据系统需要来动态调整内存使用。

在支持多用户的系统上,由于内存占用的增大,容易出现物理内存被消耗尽的情况。

为了解决物理内存被耗尽的问题,内存管理子系统规定页面可以移出内存并放入磁盘中,这个过程称为交换。

内存管理的源代码可以在./linux/mm中找到虚拟文件系统在不同格式的文件分区上,程序都可以正确地读写文件,并且结果是一样的。

有时在使用linux 系统的时候发现,可以在不同类型的文件分区内直接复制文件,对应用程序来说,并不知道文件系统的类型,甚至不知道文件的类型,这就是虚拟文件系统在背后做的工作。

虚拟文件系统屏蔽了不同文件系统间的差异,向用户提供了统一的接口。

虚拟文件系统,即VFS(Virtual File System)是Linux 内核中的一个软件抽象层。

它通过一些数据结构及其方法向实际的文件系统如ext2,vfat等提供接口机制。

通过使用同一套文件I/O 系统调用即可对Linux中的任意文件进行操作而无需考虑其所在的具体文件系统格式;更进一步,文件操作可以在不同文件系统之间进行。

在linux系统中,一切都可以被看做是文件。

不仅普通的文本文件、目录可以当做文件进行处理,而且字符设备、块设备、套接字等都可以被当做文件进行处理。

这些文件虽然类型不同,但是却使用同一种操作方法。

这也是UNIX/Linux设计的基本哲学之一。

虚拟文件系统(简称VFS)是实现“一切都是文件”特性的关键,是Linux内核的一个软件层,向用户空间的程序提供文件系统接口;同时提供了内核中的一个抽象功能,允许不同类型的文件系统存在。

VFS可以被理解为一种抽象的接口标准,系统中所有的文件系统不仅依靠VFS共存,也依靠VFS 协同工作。

为了能够支持不同的文件系统,VFS定义了所有文件系统都支持的、最基本的一个概念上的接口和数据结构,在实现一个具体的文件系统的时候,需要向VFS提供符合VFS 标准的接口和数据结构,不同的文件系统可能在实体概念上有差别,但是使用VFS接口时需要和VFS定义的概念保持一致,只有这样,才能实现对用户的文件系统无关性。

VFS 隐藏了具体文件系统的操作细节,所以,在VFS这一层以及内核其他部分看来,所有的文件系统都是相同的。

对文件系统访问的系统调用通过VFS软件层处理,VFS根据访问的请求调用不同的文件系统驱动的函数处理用户的请求。

文件系统的代码在访问物理设备的时候,需要使用物理设备驱动访问真正的硬件。

网络堆栈编写网络应用程序,使用socket通过TCP/IP协议与其他机器通信,和前面介绍的内核子系统相似,socket相关的函数也是通过内核的子系统完成的,担当这部分任务的是内核的网络子系统,有时也把这部分代码称为“网络堆栈”。

Linux内核提供了优秀的网络处理能力和功能,这与网络堆栈代码的设计思想是分不开的,Linux的网络堆栈部分沿袭了传统的层次结构,网络数据从用户进程到达实际的网络设备需要四个层次。

实际上,在每层里面还可以分为好多层次,数据传输的路径是按照层次来的,不能跨越某个层次。

linux网络子系统对网络层次采用了类似面向对象的设计思路,把需要处理的层次抽象为不同的实体,并且定义了实体之间的关系和数据处理流程。

可以看出,linux内核网络子系统定义了4个实体:网络协议网络协议可以理解为一种语言,用于网络中不同设备之间的通信,是一种通信的规范。

套接字套接字是内核与用户程序的接口,一个套接字对应一个数据连接,并且向用户提供了文件I/O,用户可以像操作文件一样在数据连接上收发数据,具体的协议处理由网络协议部分处理。

套接字是用户使用网络的接口。

设备接口设备接口是网络子系统中软件和硬件的接口,用户的数据最终是需要通过网络硬件设备发送和接收的,网络设备千差万别,设备驱动也不尽相同,通过设备接口屏蔽了具体设备驱动的差异。

网络缓冲区网络缓冲区也称为套接字缓冲区(sk_buff),是网络子系统中的一个重要结构。

网络传输数据存在许多不定因素,除了物理设备对传输数据的限制(例如MMU),网络受到干扰、丢包、重传等,都会造成数据的不稳定,网络缓冲区通过对网络数据的重新整理,使业务处理的数据包是完整的。

网络缓冲区是内存中的一块缓冲区,是网络系统与内存管理的接口。

设备驱动随着现代计算机外部设备的不断增加,起来越多的设备被开发出来,计算机总线的发展也很迅速,操作系统的功能也在不断提升,系统软件越来越复杂,对于外部设备的访问已经不能像DOS年代那样直接访问设备的硬件了,几乎所有的设备都需要设备驱动程序。

现代操作系统几乎都提供了具体硬件无关的设备驱动接口,这样的好处是屏蔽了具体设备的操作细节,用户通过操作系统提供的接口就可以访问设备,而具体设备的操作细节由设备驱动完成,驱动程序开发人员只需要向操作系统提供相应接口即可。

与其他的操作系统对设备进行复杂的分类不同,linux内核把设备分成3类:块设备、字符设备和网络设备。

这是一种抽象的分类方法,从设备的特性抽象出了3种不同的数据读写方式。

块设备块设备的概念是一次I/O操作可以操作多个字节的数据,数据读写有缓冲,当读写缓冲满以后才会传送数据,比如硬盘可以一次读取一个扇区的数据,同时,块设备支持随机读写操作,可以从指定的位置读写数据;字符设备字符设备的访问方式是线性的,并且可以按照字节的方式访问,比如串口设备,可以按照字符读写数据,但是只能按照顺序操作,不能指定某个地址访问;网络设备网络设备与前面的两种方式相比,比较特殊,内核专门把这类驱动单独划分出来,网络设备可以通过套接口读写数据。

相关文档
最新文档