IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> CPU结构对Redis性能的影响 -> 正文阅读

[大数据]CPU结构对Redis性能的影响

CPU结构对Redis性能的影响

CPU架构

CPU多核架构

一个CPU处理器一般包含多个运行核心,每个运行核心被称为一个物理核,而根据现在主流的CPU架构一般一个物理核心运行两个超线程也称为逻辑核,两个逻辑核会共享一级缓存(L1 cache)包括一级指令缓存以及一级数据缓存,二级缓存(L2 cache),但需要注意的是一级缓存和二级缓存是物理核私有,那么只有在同一个物理核的逻辑核才会共享,不同物理核是不共享的。

一级缓存和二级缓存的速度是非常快的,物理核访问它们的延迟不会超过10纳秒,但是由于一级缓存和二级缓存的制造技术有限,存储的数据只是kb级别的,如果存储的数据不在缓存中,那么只能去内存中查找而程序访问内存的速度为100多纳秒,速度差距近10倍,为了平衡内存和一级缓存,二级缓存的速度差异,CPU还会有三级缓存,三级缓存容量能达到几MB到几十MB,而且不同的物理核之间还会共享三级缓存。

图片

NUMA架构

目前为了提升服务器性能一个服务器上会存在多个CPU,也会有多个CPU插槽(也称为CPU socket),每个CPU存在多个物理核,每个CPU之间通过总线连接,结构图如下。

图片

在多CPU架构中,一个应用程序可能因为系统调用将程序从CPU Socket1切换到CPU Socket2,如果这时程序再次访需要请求CPU Socket1的内存,这种远程访问会增加应用程序的延迟。

这种架构统一称为非统一内存访问架构(Non-Uniform Memory Access,NUMA 架构),用专业术语描述就是多架构下,一个应用程序访问所在的Socket的本地内存和访问远端内存的延迟不一致的情况,这种架构统称为NUMA架构。

CPU多核对Redis性能的影响

一个程序在CPU其中一个运行核上运行,应用程序需要加载软硬件资源信息(栈指针、CPU寄存器的值等),统称为运行时信息,同时应用程序访问最频繁的值还会放入一级缓存和二级缓存中来提高响应速度。

如果程序运行过程中发生了上下文切换(context switch,当一个线程在一个CPU核上运行后切换到另外一个CPU核上这样的执行过程称为上下文切换),那么Redis的运行时信息将需要重新加载到另外一个CPU核,并且当前CPU核上如果没有指令或者数据,那么需要从三级缓存甚至内存中加载,这样会增加程序的处理时间。

如果程序频繁的进行上下文切换,那么上述场景将经常发生,如何避免频繁的上下文切换呢?可以将Redis的处理程序绑定在某个CPU核上,这样CPU的上下文切换自然少了很多,操作系统提供了指令taskset可以绑定CPU核与Redis进程之间的关系,同时还能重复利用一级缓存和二级缓存。

###?将Redis进程绑定到0号核上,绑定多个核用逗号分隔
taskset?-c?0?./redis-server

多CPU对Redis性能的影响

多CPU架构又被称为NUMA架构,不同的CPU间通信依靠总线,当不同的处理程序位于不同的CPU时,花费在通信上的时间较多,以Redis的网络中断程序为例。

Redis网络中断处理程序会从网卡中读取中断信息,放入到Redis的内核缓存区中,Redis通过epoll机制触发事件,通知Redis实例,Redis实例从内核缓存区中读取事件,写入到实例内存中,如下所示。

图片

在上述示例中,如果网络中断处理程序和Redis实例不在一个CPU中,那么网络中断处理程序和Redis实例的访问需要跨CPU访问,带来的后果就是需要消耗过多的时间,拖慢网络中断处理速度,示意图如下

图片

解决办法就是将Redis实例和网络中断处理程序绑定在一个CPU上,这样Redis实例访问中断数据就是本地访问,节省传输开销,如下所示。

图片

在绑定运行核时,需要注意的是CPU逻辑核编号规则是先给每一个CPU socket的物理核的第一个逻辑核依次编号,再给物理核的第二个逻辑核编号,示意图如下所示。

图片

另外需要注意的是单独绑定一个逻辑核,那么对于一个Redis实例而言,并不是只有主线程,还有用于持久化的RDB子进程、AOF文件重写进程、以及4.0版本后用于惰性删除的进程等等,这些子进程会和主进程竞争CPU资源,所以在绑定的时候可以绑定一个物理核(通常一个物理核包含两个逻辑核),如上图那么可以执行如下命令绑定,这样可以减少其它子线程对于主线程的CPU资源竞争。

###?0和12号逻辑核都是0号物理核
taskset?-c?0,12?./redis-server

  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2022-05-06 11:06:45  更:2022-05-06 11:08:42 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/16 8:00:53-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码