Linux课程总结报告

Linux系统的一般执行过程

一般情况

正在运行的用户态进程X切换到运行用户态进程Y的过程

  1. 正在运行的用户态进程X
  2. 发生中断:save cs:eip/esp/eflags(current) to kernel stack,then load cs:eip(entry of a specific ISR) and ss:esp(point to kernel stack).
  3. SAVE_ALL //保存现场
  4. 中断处理过程中或中断返回前调用了schedule(),其中的switch_to做了关键的进程上下文切换
  5. 标号1之后开始运行用户态进程Y(这里Y曾经通过以上步骤被切换出去过因此可以从标号1继续执行)
  6. restore_all //恢复现场
  7. iret - pop cs:eip/ss:esp/eflags from kernel stack
  8. 继续运行用户态进程Y

特殊情况

  1. 通过中断处理过程中的调度时机,用户态进程与内核线程之间互相切换和内核线程之间互相切换,与最一般的情况非常类似,只是内核线程运行过程中发生中断没有进程用户态和内核态的转换;
  2. 内核线程主动调用schedule(),只有进程上下文的切换,没有发生中断上下文的切换,与最一般的情况略简略;
  3. 创建子进程的系统调用在子进程中的执行起点及返回用户态,如fork;
  4. 加载一个新的可执行程序后返回到用户态的情况,如execve。

结合虚拟化技术分析Linux系统的一般执行过程

在Linux系统中虚拟机启动时,其执行过程与物理机有所不同。

  1. 在虚拟化环境下,虚拟化层会拦截所有的硬件访问,并将其重定向到虚拟机中。这意味着在启动引导程序时,虚拟化层会加载虚拟机的引导程序而非物理主机上的引导程序;
  2. 在第3步时,虚拟化层会加载虚拟机的操作系统内核,而不是物理主机上的操作系统内核。每个虚拟机都可以运行自己的Linux系统,就好像它们在各自的物理计算机上一样;
  3. 在启动用户空间时,虚拟化层会为每个虚拟机提供独立的资源,并对它们进行隔离,以确保它们之间不会相互干扰。

虚拟化技术在Linux系统中的应用,可以实现一台物理主机上同时运行多个虚拟机,实现资源共享和隔离,同时也能够确保每个虚拟机都可以独立运行自己的操作系统。

课程收获

在这学期的Linux操作系统分析课程中,我对Linux系统有了更加深入的了解,而不是仅限于对Linux操作系统的使用。在这学期的课程中我学到的知识有以下几点:Linux操作系统的架构,如内核、Shell、文件系统等,以及它们之间协同提供完整操作系统的基本原理;学习了Linux中进程的创建、终止以及进程调度机制,帮助我深入理解了操作系统的并发性;学习了系统调用的概念和用途。在课程实验中,通过使用qemu调试Linux内核,使我熟悉了Linux常用操作和命令,更直观地理解了理论课中的知识点和原理。这门课为我带来的不仅是专业知识的增长,更提高了我面对不熟悉的知识时的学习探索能力。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值