CPU中的上下文
一.简介
Linux是多任务操作系统,cpu划分固定时间片,分给每个进程,当前进程时间片执行完毕,将挂起,运行下一个进程。而进程运行时,需要到寄存器中获得要运行的指令和指令所在内存的位置。
cpu上下文切换,就需要将寄存器中的数据保存到系统内核中,加载新程序的寄存器信息,跳转到计数器所指定的内存位置,开始读取和运行新进程。每次切换需要消耗cpu,繁上下文切换会影响性能。
二.进程切换
Linux 按照特权等级,把进程的运行空间分为内核空间和用户空间。0为内核态,3为用户态
一个进程如果要输出一些信息,只需要在用户空间完成即可,但要读取文件,就需要到内核空间完成,这个转变,就需要系统调用。需要把原先用户态的指令保存,加载内核态的指令到进寄存器,完成指令。这种不会涉及虚拟内存等用户态资源。只是同进程中,为了完成不同权限指令的切换。
进程由内核管理和调度,切换发生在内核态。上下文中保存了虚拟内存,栈,全局变量等用户空间资源,也保存了内核堆栈,寄存器等内核空间资源。因为除了保存寄存器信息,还需要刷新TLB管理的虚拟内存和用户栈
cpu在每个核心上维护了一个就绪列队,将正在运行和等待运行的进程按优先级和等待cpu时间排序。选择优先级最高和等待cpu时间最长的进程运行。
切换理由:
1.cpu划分固定时间片,分给每个进程,当前进程时间片执行完毕,将挂起,运行下一个进程。
2.运行sleep函数,自动挂起。
3.当前进程资源不足,例如内存需要2G,但内存不够,将挂起,当满足后再运行。
4.有优先级更高的进程,则当前进程挂起,运行新进程。
5.硬件中断,进程挂起,执行内核中的中断服务。
三.线程切换
进程是拥有资源的集合体,而线程是执行操作的单位。关系很像公司中部门和人员的关系。每个部分都有不同的资源,而部门中的人员则使用资源完成任务。
当只有一个线程的时候,线程等于进程
当有多个线程的时候,线程共享虚拟内存,全局变量等资源,这些资源上写文切换时不需要更改。
线程有自己的单独数据,栈和寄存器重存储的内容,切换需要保存。
切换理由:
前后2个线程属于不同进程,等同于进程的切换
前后2个线程属于同进程,切换只需要保存私有数据
相比进程的切换,将要节省更多资源
四.中断切换
当有硬件事件,例如在键盘打字,就会中断当前进程,响应硬件设备。中断切换并不涉及进程用户态,不需要保存和恢复虚拟内存,全局变量等用户态资源。只保存内核态,中断服务程序执行所必须的状态,包括cpu寄存器,内核堆栈,硬件终端参数等。
同cpu中,中断优先级最高,所以中断切换和进程之前切换并不会同时发生。
五.中断检测和查看
1.检查上下文切换情况
vmstat
cs(context switch)是每秒上下文切换的次数
in(interrupt)则是每秒中断的次数
r(Running or Runnable)是就绪队列的长度,也就是正在运行和等待 CPU 的进程数
b(Blocked)则是处于不可中断睡眠状态的进程数
2.每个进程的上下文切换情况
pidstat -w 5
cswch(voluntary context switches)每秒自愿上下文切换的次数
是指进程无法获取所需资源,导致的上下文切换,例如I/O、内存等系统资源不足时
nvcswch(non voluntary context switches)每秒非自愿上下文切换的次数
指进程由于时间片已到,有优先级更高的进程启动等原因,被系统强制调度从而切换。当大量进程抢夺cpu时,就容易发生此类切换。
六.模拟
sysbench,多线程基准测试工具
使用sysstat来检查监控和分析,包含mpstat用于查看每颗cpu的状态,pidstat查看每个进程的状态
rpm -ivh https://mirrors.aliyun.com/epel/epel-release-latest-7.noarch.rpm
yum -y install sysbench sysstat
1.查看空闲系统上下文切换数据,3秒一次
vmstat 3
2.单独开一个终端
以 10 个线程运行 5 分钟的基准测试,模拟多线程切换的问题
sysbench --threads=10 --max-time=300 threads run
3.返回第一个终端,可以看到突然变大
r 列:就绪队列的长度已经到了 8,远远超过了系统 CPU,会导致频繁切换
us(user)和 sy(system)列:这两列的 CPU加起来就是100%,sy最高,主要是内核占用
in 列:中断次数也上升到了 1k左右,说明中断处理也是问题
说明等待使用cpu的进程太多,导致大量上下文切换,上下文切换导致cpu占用率升高。
4.查看具体应用
-w 参数表示输出进程切换指标,-u 参数则表示输出 CPU 使用指标
pidstat -w -u 3
可以看到sysbench占用了很高的cpu使用率很高,但没有产生多少上下文切换
5.查看多线程,-t显示线程
pidstat -wt 3
可以看到线程占用的很多
6.查看中断信息
/proc/interrupts 这个只读文件中读取,/proc 实际上是 Linux 的一个虚拟文件系统。/proc/interrupts 就是这种通信机制的一部分,用于内核空间与用户空间之间的通信,提供了一个只读的中断使用情况。
watch -d cat /proc/interrupts
CPU中的上下文的更多相关文章
- paip.提升性能--多核cpu中的java/.net/php/c++编程
paip.提升性能--多核cpu中的java/.net/php/c++编程 作者Attilax 艾龙, EMAIL:1466519819@qq.com 来源:attilax的专栏 地址:http ...
- 如何添加“在这里打开PowerShell”到Windows中的上下文菜单
It was only a matter of time, right? Due to my recent infatuation passionate love affair with PowerS ...
- 【转】Python之向日志输出中添加上下文信息
[转]Python之向日志输出中添加上下文信息 除了传递给日志记录函数的参数(如msg)外,有时候我们还想在日志输出中包含一些额外的上下文信息.比如,在一个网络应用中,可能希望在日志中记录客户端的特定 ...
- 14.翻译系列:从已经存在的数据库中生成上下文类和实体类【EF 6 Code-First系列】
原文链接:https://www.entityframeworktutorial.net/code-first/code-first-from-existing-database.aspx EF 6 ...
- (转)Python中的上下文管理器和Tornado对其的巧妙应用
原文:https://www.binss.me/blog/the-context-manager-of-python-and-the-applications-in-tornado/ 上下文是什么? ...
- 5.翻译:EF基础系列---EF中的上下文类
原文地址:http://www.entityframeworktutorial.net/basics/context-class-in-entity-framework.aspx EF中的上下文类是一 ...
- [知识库:python-tornado]异步调用中的上下文控制Tornado stack context
异步调用中的上下文控制Tornado stack context https://www.zouyesheng.com/context-in-async-env.html 这篇文章真心不错, 非常透彻 ...
- Python 日志输出中添加上下文信息
Python日志输出中添加上下文信息 除了传递给日志记录函数的参数(如msg)外,有时候我们还想在日志输出中包含一些额外的上下文信息.比如,在一个网络应用中,可能希望在日志中记录客户端的特定信息,如: ...
- Python协程中使用上下文
在Python 3.7中,asyncio 协程加入了对上下文的支持.使用上下文就可以在一些场景下隐式地传递变量,比如数据库连接session等,而不需要在所有方法调用显示地传递这些变量.使用得当的话, ...
随机推荐
- Hadoop HA集群 与 开发环境部署
每一次 Hadoop 生态的更新都是如此令人激动 像是 hadoop3x 精简了内核,spark3 在调用 R 语言的 UDF 方面,速度提升了 40 倍 所以该文章肯定得配备上最新的生态 hadoo ...
- ESP32-S3 搭建 micropython 开发环境,固件编译,烧录
简述 上手了一块乐鑫科技官方推出的ESP32-S3-DevKitC-1开发板,发现 ESP32-S3 的综合性能较比前两代有着非常明显的提升,wifi与蓝牙功能,更充足的外设扩展能力,可以看出其在未来 ...
- 使用Python定时清理运行超时的pdflatex僵尸进程
问题 在我们之前的<基于texlive定制chemfig化学式转换Python服务镜像>定制的pdflatex在线转换的镜像已经运行在生产环境了,但是最近总有人反馈服务跑着跑着就慢了,本来 ...
- pcm-pcie 解析
简介 pcm 全称为 Performance Counter Monitor,该项目是针对 intel 平台处理器的资源利用率进行监控的工具.在现代 Intel 处理器已经提供了监视处理器内部性能事件 ...
- Excel-计算年龄、工龄 datedif()
函数名称:DATEDIF 主要功能:计算返回两个日期参数的差值. 使用格式:=DATEDIF(date1,date2,"y").=DATEDIF(date1,date2," ...
- 17.Power of Four-Leetcode
#define IMIN numeric_limits<int>::min() #define IMAX numeric_limits<int>::max() class So ...
- kubernetes整个基础环境的准备
1.三台centos7,用CentOS-7-x86_64-Minimal-1708.iso安装的,记得统一选好时区,这三台会有etcd集群,其中一台做kubernetes服务端(也可以做三台服务端做负 ...
- WebRTC视频分辨率设置
前面我们能够打开摄像头.getUserMedia()时会传入参数,在参数里我们可以指定宽高信息.通过宽高参数控制输出的视频分辨率. html 在页面上摆放一些元素,下面是主要部分 <div id ...
- Java8 Lambda表达式、函数式接口和方法引用
目录 Java8 Lambda表达式和函数式接口 Lambda表达式 Lambda的使用 函数式接口FunctionalInterface Java内置四大核心函数式接口 方法引用 构造器引用 Jav ...
- C++ 写出这个数
题目如下: 读入一个正整数 n,计算其各位数字之和,用汉语拼音写出和的每一位数字. 输入格式: 每个测试输入包含 1 个测试用例,即给出自然数 n 的值.这里保证 n 小于 1. 输出格式: 在一行内 ...