性能测试之_04cpu上下文切换,查看中断类型,查看自愿和非自愿

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
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值