Redis是否需要绑定CPU?

商务办公 Redis
在多核服务器上,绑定CPU可以减少上下文切换,尤其是服务器上还运行有其它应用时,REDIS主线程被调度到其它CPU核上时,这时会使用其它核上的L1、L2缓存,如果有其它应用程序也使用了缓存,这样会降低命中率。

[[429335]]

在多核服务器上,绑定CPU可以减少上下文切换,尤其是服务器上还运行有其它应用时,REDIS主线程被调度到其它CPU核上时,这时会使用其它核上的L1、L2缓存,如果有其它应用程序也使用了缓存,这样会降低命中率。

现在服务器一般都是多核的,绑定CPU看起来是一个必然正确的选项,但实际上是有风险的!

在NUMA架构下,操作系统的网络中断程序与REDIS线程可能不在同一个CPU socket上,会导致REDIS线程访问内存变慢,这个时候就需要把网络中断程序与REDIS线程绑定在同一个CPU socket内的不同物理核上,以解决跨CPU socket访问问题。

图片

那绑定CPU还有其它风险吗?

如果绑定了CPU逻辑核后,会导致REDIS子进程都会绑定在这个逻辑核上,这样RDB、AOF等操作都会与REDIS主线程竞争同一个逻辑核。

 

优化方式为改绑定物理核,或者修改源码使用后台程序及子进程使用其它CPU。

 

责任编辑:武晓燕 来源: 肌肉码农
相关推荐

2021-07-07 10:05:38

进程CPULinux

2009-01-03 15:32:26

SAN存储区域网存储设备

2021-07-15 08:00:47

系统性能调优cpunuma架构

2009-11-12 09:29:11

ChromeGoogleToolbar

2019-08-23 09:56:41

公共云云遣返多云

2010-07-21 09:32:03

Linux多核

2019-08-21 15:38:00

CPU超频主板

2011-10-19 10:22:02

Android游戏平台

2012-03-05 20:27:58

iPhone

2012-07-06 09:34:48

虚拟防火墙

2013-06-09 10:00:38

BYODBYOD策略云计算平台

2019-11-08 13:46:54

存储云计算系统

2019-10-12 11:12:37

云计算高性能计算系统

2013-08-09 14:23:09

Android应用Android退出按钮Android开发设计

2022-01-11 11:18:16

Overlay云计算网工

2018-04-08 09:20:00

LinuxCPU虚拟化技术

2023-01-31 17:24:21

DPUCPUGPU

2020-08-13 14:58:06

Spark小文件存储

2015-04-08 10:39:10

云存储云存储技术标准

2013-10-30 09:23:39

硬件安全模块CloudHSMHSM
点赞
收藏

51CTO技术栈公众号