NUMA架构:CPU和内存性能瓶颈的终结者!
NUMA的出现
我们都知道,CPU是计算机的核心组件,它被设计用来完成计算机的核心任务:计算,这里的计算既包括数学上的运算,还包括条件的判断、IO设备的读写等多个方面。
在计算机发展初期,为了提升CPU的计算能力,工程师们的方法是不断增加晶体管的数量和提升CPU的主频,因为这可以让CPU在单位时间内完成更多次数的计算。
然而,当技术发展到一定程度之后,CPU的散热和功耗的问题开始变得突出,单纯提升主频开始变得越来越困难,然后工程师们又有了新的想法:既然一个人干活效率有限,那就让更多的人一起干活吧!于是,多核CPU应运而生。
多核CPU可以同时处理多个任务,极大地提高了计算机的运算速度。然而,随着核心数量的增加,新的问题也随之出现。在多核CPU系统中,所有的核心共享同一块内存,当多个核心同时访问内存时,就会产生争用,这种争用会导致内存访问的延迟增加,从而影响系统的整体性能。
为了解决这个问题,工程师们又提出了非统一内存访问(NUMA)架构。在NUMA架构中&#