深入理解Linux内核-进程
1、进程的静态特性
进程:程序执行时的一个实例 进程描述符(task_struct): 进程的基本信息(thread_info)、指向内存区描述符的指针(mm_struct)、进程相关的tty(tty_struct)、当前目录(fs_struct)、指向 文件描述符的指针(files_struct)、所接收的信号(signal_struct) 进程状态:1、可运行状态(TASK_RUNNING):正在运行或者准备执行
2、可中断的等待状态(TASK_INTERRUPTIBLE):进程挂起,产生硬件中断、接收到信号被唤醒进入TASK_RUNNING状态
3、不可中断的等待状态(TASK_UNINTERRUPTIBLE):类似上述;不能被中断
4、暂停状态(TASK_STOPPED):进程的执行被暂停
5、跟踪状态(TASK_TRACED):
6、僵死状态(EXIT_ZOMBIE):进程的执行被终止,但是父进程没有发布wait()类系统调用,内核不能丢弃包含在死进程描述符中的数据
7、僵死撤销状态(EXIT_DEAD):父进程发布wait()类系统调用,进程由系统删除。为了避免其他进程的竞争,将进程由僵死状态改为僵死撤销状态。 PID:进程描述符processID,32位系统默认上限32767,64位系统默认上限4194303。用位图表决PID的闲置状态 魔数常量:将2^32做黄金分割,取最接近这个值的一个素数。即0x9e370001(2 654 404 609)= 2^31 + 2^29 - 2^25 + 2^22 - 2^19 - 2^16 +1 进程资源限制:Linux中,进程对系统资源的占用受到一些限制,避免用户过分使用系统资源;CPU时间、地址空间、文件大小、堆大小、栈大小、进程数等等
2、内核如何进行进程切换
硬件上下文:每个进程有自己有地址空间,但是必须共享CPU寄存器;进程恢复前必须装入寄存器的一组数据称为硬件上下文(hardware context)。
进程切换前,需要先切换硬件上下文;被切换打硬件上下文保存在进程描述符的字段thread_struct的thread字段中。另外通用寄存器的值保留在内核堆栈中。 进程切换:1、切换页全局目录以安装一个新的地址;2、切换内核堆栈和硬件上下文 另外还有一些其他的寄存器或者协处理器:FPU(算术浮点单元)、MMX(multi media extension 多媒体扩展指令集)、SSE/SSE2(Streaming SIMD Extensions)等需要考虑切换; SIMD(single - instruction multiple-data 单指令多数据)
3、进程的创建
提高创建进程效率的方法:写时复制、轻量级进程(允许父子进程共享在内核的很多数据结构)、vfork()创建的进程能共享父进程的内存地址空间。 创建进程的三种方法:clone(), fork(), vfork() clone(): 创建轻量级进程 fork(): 由clone() 实现, 传入的参数不同 vfork(): 由clone() 实现, 传入的参数不同 进程0: swapper进程、idle进程; 在多处理器系统中,每个CPU都有一个进程0 进程1: 内核进程, 与进程0共享数据,也叫做init进程,它创建和监控在操作系统外层执行的所有进程活动。
4、进程的撤销
exit(): 系统调用,用来终止某一个进程 exit_group(): 系统调用,终止整个线程组 僵尸进程:产生掉一个原因是父进程已死,无法调用wait函数结束子进程,释放其进程描述符。这个时候需要强制子进程称为init进程的子进程,由init来通知释放
5、Linux对多线程程序多支持
深入理解Linux内核-进程的更多相关文章
- 深入理解linux内核-进程和程序
进程描述符task_struct task_struct { //进程基本信息 pid 进程id号 tgid 线程组id号,与线程组领头线程pid号相同 getpid()返回该值 tasks in ...
- 读书笔记之Linux系统编程与深入理解Linux内核
前言 本人再看深入理解Linux内核的时候发现比较难懂,看了Linux系统编程一说后,觉得Linux系统编程还是简单易懂些,并且两本书都是讲Linux比较底层的东西,只不过侧重点不同,本文就以Linu ...
- 《深入理解Linux内核》 读书笔记
深入理解Linux内核 读书笔记 一.概论 操作系统基本概念 多用户系统 允许多个用户登录系统,不同用户之间的有私有的空间 用户和组 每个用于属于一个组,组的权限和其他人的权限,和拥有者的权限不一样. ...
- 【读书笔记::深入理解linux内核】内存寻址【转】
转自:http://www.cnblogs.com/likeyiyy/p/3837272.html 我对linux高端内存的错误理解都是从这篇文章得来的,这篇文章里讲的 物理地址 = 逻辑地址 – 0 ...
- 【读书笔记::深入理解linux内核】内存寻址
我对linux高端内存的错误理解都是从这篇文章得来的,这篇文章里讲的 物理地址 = 逻辑地址 – 0xC0000000:这是内核地址空间的地址转换关系. 这句话瞬间让我惊呆了,根据我的CPU的知识,开 ...
- 《深入理解linux内核》第三章 进程
进程的七种状态 在内核源码的 include/linux/sched.h文件中: task_struct的status可表示 #define TASK_RUNNING 0 #define TASK_I ...
- 尝试理解Linux容器进程与宿主机共享内核到底是什么意思?
背景 近期接触容器技术时,经常看到各类比较容器与虚拟机区别的文章中会提到:容器是共享宿主机的内核,而虚拟机则是拥有自己独立的内核,所以不可能在Linux上用容器运行windows,但是用虚拟机则可以. ...
- linux内核--进程与线程
http://blog.csdn.net/yusiguyuan/article/details/12154823 在<linux内核设计与实现>中第三章讲解了进程管理,在关于进程和线程的概 ...
- 理解Linux的进程,线程,PID,LWP,TID,TGID
在Linux的top和ps命令中,默认看到最多的是pid (process ID),也许你也能看到lwp (thread ID)和tgid (thread group ID for the threa ...
- linux内核——进程管理
在讲进程之前先说一下进程的堆栈的吧: 1.进程的堆栈 内核在创建进程的时候,在创建task_struct的同一时候,会为进程创建对应的堆栈.每一个进程会有两个栈,一个用户栈.存在于用户空间,一个内核栈 ...
随机推荐
- 编译安装linux内核步骤
编译安装linux内核步骤: 一.获取内核源码 源码网址:www.kernel.org 二.解压内核源码 首先以root帐号登录,然后进入/usr/src子目录.如果用户在安装Linux时,安装了内核 ...
- quartz持久化部署实现
http://blog.csdn.net/wxniitxueyuan/article/details/50477712
- CSS3 flex的使用方法
display:flex; align-items://水平对齐方式 justify-content://垂直对齐方式 flex://盒子所占大小(如果你盒子里面只有两个div,那么你设置其中之一个f ...
- 【TP5.0】model的操作方法
tp5 中 model 的新增方法 //默认主键为自动识别,如果需要指定,可以设置属性: namespace app\index\model; use think\Model; class User ...
- 【LeetCode】230. Kth Smallest Element in a BST (2 solutions)
Kth Smallest Element in a BST Given a binary search tree, write a function kthSmallest to find the k ...
- 系统服务中没有Windows Installer服务怎么办
在安装软件时,发现安装不了,提示没有Windows Installer服务,到系统服务中一看,果真没有这一项,这是什么问题呢? 出现这种情况,多为与Windows Installer服务相关的文件丢失 ...
- Windows Server 2008中安装IIS7.0
最近由于需求重新部署了一台服务器Windows Server 2008,由于以前都是在Windows Server 2003上操作,因此记录下,供其他同学参考. 下面主要介绍在Windows Se ...
- Swift 下标脚本
前言 在访问一个数组实例的元素时,可以使用 Array[index] 的形式.在访问一个字典实例的元素时,可以使用 Dictionary[index] 的形式.这种方括号的形式就是 "下标脚 ...
- Snip for Mac(桌面截图工具)安装
1.软件简介 Snip 一款用于桌面截图的工具. 2.资源列表 链接 提取密码 系统要求 软件语言 Snip for Mac v2.0 (5771) fgab macOS 10.6.8 及以上 ...
- MongoDB----逻辑与物理存储结构
基本的操作 一.常用的命令和基础知识 1.进入MongoDB shell 首先我们进入到MongoDB所在目录执行 cd /work/app/mongodb/bin/ #启动 ./mongo 为了方便 ...