1、CPU上下文
任务运行前,CPU 都需要知道任务从哪里加载、又从哪里开始运行,也就是说,需要系统事先帮它设置好 CPU 寄存器和程序计数器
1.1、CPU上下文两部分:
1.1、CPU 寄存器:是 CPU 内置的容量小、但速度极快的内存
1.2、程序计数器:用来存储 CPU 正在执行的指令位置、或者即将执行的下一条指令位置。它们都是 CPU 在运行任何任务前,必须的依赖环境
2、CPU 上下文切换分为进程上下文切换、线程上下文切换以及中断上下文切换3种场景。
2.1、进程
进程是资源分配和执行的基本单位
进程给指针提供虚拟内存、栈、变量等共享资源
2.2、线程
线程是任务调度和运行的基本单位。线程没有资源
线程可以共享进程的资源
2.3、进程上下文切换
进程上下文切换,指的是一个进程切换到另一个进程
进程既可以在用户空间运行,又可以在内核空间中运行
分为:内核空间,用户空间,两部分
1 、内核空间Ring0:进程内核空间的时候,被称为进程的内核态
2 、用户空间Ring3:进程在用户空间运行时,被称为进程的用户态
用户态到内核态的转变,需要通过系统调用来完成,所以一次系统调用的过程,其实是发生了两次 CPU 上下文切换
2.4、线程上下文切换
分为:前后两个线程属于不同进程,前后两个线程属于同一个进程,两部分
1、前后两个线程属于不同进程:此时,因为资源不共享,所以切换过程就跟进程上下文切换是一样
2、前后两个线程属于同一个进程:此时,因为虚拟内存是共享的,所以在切换时,虚拟内存这些资源就保持不动,只需要切换线程的私有数据、寄存器等不共享的数据
2.4.1、上下文切换两种类型
2.4.1.1、自愿上下文切换:
进程无法获取所需资源,导致上下文切换
例如,I/O、内存等系统资源不足时,就会发生。
自愿上下文切换变多了,说明进程都在等待资源,有可能发生了 I/O 等其他问题
2.4.1.2、非自愿上下文切换:
则是指进程由于时间片已到等原因,被系统强制调度,进而发生的上下文切换
例如,大量进程都在争抢 CPU 时,就容易发生非自愿上下文切换。
非自愿上下文切换变多了,说明进程都在被强制调度,也就是都在争抢 CPU,说明 CPU 的确成了瓶颈
2.4.3、查看上下文切换情况
// -w参数表示输出进程切换指标,而-u参数则表示输出CPU使用指标
// pidstat 默认显示进程的指标数据,加上 -t 参数后,才会输出线程的指标。
pidstat 5 -w -u
Linux 3.10.0-1062.4.1.el7.x86_64 (instance-010oj085) 04/04/2020 _x86_64_ (2 CPU