一.简介

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中的上下文的更多相关文章

  1. paip.提升性能--多核cpu中的java/.net/php/c++编程

    paip.提升性能--多核cpu中的java/.net/php/c++编程 作者Attilax  艾龙,  EMAIL:1466519819@qq.com  来源:attilax的专栏 地址:http ...

  2. 如何添加“在这里打开PowerShell”到Windows中的上下文菜单

    It was only a matter of time, right? Due to my recent infatuation passionate love affair with PowerS ...

  3. 【转】Python之向日志输出中添加上下文信息

    [转]Python之向日志输出中添加上下文信息 除了传递给日志记录函数的参数(如msg)外,有时候我们还想在日志输出中包含一些额外的上下文信息.比如,在一个网络应用中,可能希望在日志中记录客户端的特定 ...

  4. 14.翻译系列:从已经存在的数据库中生成上下文类和实体类【EF 6 Code-First系列】

    原文链接:https://www.entityframeworktutorial.net/code-first/code-first-from-existing-database.aspx EF 6 ...

  5. (转)Python中的上下文管理器和Tornado对其的巧妙应用

    原文:https://www.binss.me/blog/the-context-manager-of-python-and-the-applications-in-tornado/ 上下文是什么? ...

  6. 5.翻译:EF基础系列---EF中的上下文类

    原文地址:http://www.entityframeworktutorial.net/basics/context-class-in-entity-framework.aspx EF中的上下文类是一 ...

  7. [知识库:python-tornado]异步调用中的上下文控制Tornado stack context

    异步调用中的上下文控制Tornado stack context https://www.zouyesheng.com/context-in-async-env.html 这篇文章真心不错, 非常透彻 ...

  8. Python 日志输出中添加上下文信息

    Python日志输出中添加上下文信息 除了传递给日志记录函数的参数(如msg)外,有时候我们还想在日志输出中包含一些额外的上下文信息.比如,在一个网络应用中,可能希望在日志中记录客户端的特定信息,如: ...

  9. Python协程中使用上下文

    在Python 3.7中,asyncio 协程加入了对上下文的支持.使用上下文就可以在一些场景下隐式地传递变量,比如数据库连接session等,而不需要在所有方法调用显示地传递这些变量.使用得当的话, ...

随机推荐

  1. UDP端口检查告警SHELL脚本(企业微信版机器人版)

    脚本准备 0Batch_Check.sh 1port_check.sh 2wechat_bot_alert.sh CheckList CheckList #支持大/小写 10.1.1.5 Udp 53 ...

  2. python实现其它形态学操作

    目录: (一) 顶帽(原图像与开操作图像的差值)(二) 黑帽(原图像与闭操作图像的差值)(三) 形态学梯度  (1)基本梯度(膨胀后的图像与腐蚀后的图像差值)  (2)内部梯度(原图像减去腐蚀后的图像 ...

  3. [luogu5344]逛森林

    由于没有删边操作,可以先建出整棵森林,之后再用并查集判断是否连通,若连通必然与最后的森林相同 但如果用树链剖分+线段树的形式来优化建图,更具体如下: 建立两颗线段树,左边从儿子连向父亲,右边从父亲连向 ...

  4. Hibernate数据校验简介

    我们在业务中经常会遇到参数校验问题,比如前端参数校验.Kafka消息参数校验等,如果业务逻辑比较复杂,各种实体比较多的时候,我们通过代码对这些数据一一校验,会出现大量的重复代码以及和主要业务无关的逻辑 ...

  5. Jenkins快速上手安装

    目录 环境准备 - JDK 安装 1. APT 安装 2. WAR包方式运行 3.Docker 方式运行 Jenkins 是一个独立的开源自动化服务器,可以用来自动化与构建.测试.交付或部署软件相关的 ...

  6. 深入理解Redis 数据结构—双链表

    在 Redis 数据类型中的列表list,对数据的添加和删除常用的命令有 lpush,rpush,lpop,rpop,其中 l 表示在左侧,r 表示在右侧,可以在左右两侧做添加和删除操作,说明这是一个 ...

  7. 【洛谷1340】兽径管理(最小生成树 Kruskal)(sort的一些技巧)【2012福建省信息学奥林匹克CCF NOIP夏令营第05天训练】

    Description 约翰农场的牛群希望能够在 N 个(1<=N<=6000) 草地之间任意移动.草地的编号由 1到 N.草地之间有树林隔开.牛群希望能够选择草地间的路径,使牛群能够从任 ...

  8. ABC 210

    A 按题意模拟. scanf("%lld%lld%lld%lld",&n,&a,&x,&y); std::cout<<n * x - ( ...

  9. 洛谷 P5470 - [NOI2019] 序列(反悔贪心)

    洛谷题面传送门 好几天没写题解了,写篇题解意思一下(大雾 考虑反悔贪心,首先我们考虑取出 \(a,b\) 序列中最大的 \(k\) 个数,但这样并不一定满足交集 \(\ge L\) 的限制,因此我们需 ...

  10. time 查看命令执行时间

    在命令执行完成之后就会打印出CPU的使用情况: real    0m5.064s      <== 实际使用时间(real time) user    0m0.020s     <== 用 ...