超线程和多核心简介

超线程和多核心

在购买CPU的时候,我们往往会发现CPU的参数列表中核心数和线程数不一致,且大多数情况下线程数是核心数的两倍。这是为什么呢?这就涉及到超线程和多核心的概念。

在这里插入图片描述

超线程CPU简介

超线程技术是英特尔研发的一种技术,与2002年发布。超线程技术把多线程处理器内部的两个逻辑内核模拟成两个物流芯片,让单个处理器就能使用线程级的并行计算,使得CPU空闲资源得以充分利用。
虽然采用超线程技术能够同时执行两个线程,当两个线程同时需要某个资源时,其中一个线程必须让出资源并暂时挂起,直到这些资源空间以后才能继续。因此,超线程的性能并不等于两个CPU的性能。

在这里插入图片描述

上图是最简单的双线程CPU的一个例子。图中有两个程序计数器(PC0和PC1)及两个寄存器堆(Register File0和Register File1),它能同时执行两个线程,相当于有两个逻辑意义上的CPU(逻辑CPU)。三个功能部件(两个ALU和一个FPU)被两个逻辑CPU共享。当两个线程同时要求使用FPU时,其中一个的要求得到满足,而另一个则需要等待。

多核心CPU简介

随着半导体工艺技术的提高,在一个芯片内能集成越来越多的晶体管,并且CPU的时钟频率也越来越快。但是时钟频率不可能无限地提高(受光速影响,电子信号传播速度约为光速三分之二),而且随着频率的增加,功率和散热问题也越来越严重(据测算,主频每增加1Ghz,功耗将上升25W,而在芯片功耗超过150W后,现有的风冷散热系统将无法满足散热的需要)。所以单核处理器性能似乎达到了瓶颈,人们开始把视线放到了多核处理器上。

多核CPU就是在基板上集成多个单核CPU。

如果核的数量不是很多,一般都采用共享总线的结构。一般来说,每个核都有各自的第一级Cache和第二级Cache,共享第三级Cache,与外部的总线接口一般都只有一个。

多核CPU的Cache一致性问题

多核CPU实际上就是一个小规模的多处理机。多处理机的一个显著特点就是共享存储器。而存在于多处理机中的一个著名的问题就是Cache一致性。
多处理机解决Cache不一致问题的方法有两种。在大规模的分布式共享存储器的多处理机系统中,往往采用基于目录的协议。在小规模的基于总线的共享存储器的多处理机系统中,往往采用总线监视协议。即每个Cache控制器都要监视总线上的动作,当总线上有写动作发生时,检查自己的Cache是否有相同地址的Cache块。如果有,则或者把新的数据写入自己相应的Cache块,或者干脆把相应的Cache块置为无效。

多处理器调度方法

非对称多处理

一个处理器负责所有调度决定、I/O处理以及其他系统活动,其他的处理器只执行用户代码。非对称多处理很简单,因为只有一个处理器访问系统数据结构,减少了数据共享的需要。

对称多处理(SMP)

每个处理器自我调度。所有进程可能处于一个共同的就绪队列中,或者每个处理器都有自己的就绪进程队列。每个处理器的调度程序都检查共同就绪队列,以便选择执行一个进程。

处理器亲和性

如果一个原本在某个处理器上执行的进程转移到了另一个处理器上执行,则第一个处理器的缓存失效,而第二个处理器的缓冲需要重新填充。进程从一个处理器转移到另一个处理器上执行的代价很大,因此大多数SMP系统试图避免将进程从一个处理器转移到另一个处理器上。这就是处理器亲和性。

处理器的亲和性有两种:软亲和性和硬亲和性。软亲和性是指操作系统试图将进程保持在同一个处理器上,但不是强制的。硬亲和性则强制进程只允许在某个处理器上。

多处理器负载均衡

多处理的负载均衡是为了充分利用每个处理器的计算资源,而不至于出现一个处理器高负载,而其它处理器空闲等待的场景。对于大多数支持SMP的现代操作系统,每个处理器都有一个就绪进程队列。负载均衡通常有两种方法:推迁移和拉迁移。

推迁移
周期性地检查每个处理器的负载,如果发现不平衡,则通过将进程从超载处理器推到低负载的处理器上。

拉迁移
空闲处理器从高负载处理器上拉取一个进程执行。

  • 3
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值