REDIS是否需要绑定CPU?

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

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

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

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

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

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值