在多核服务器上,绑定CPU可以减少上下文切换,尤其是服务器上还运行有其它应用时,REDIS主线程被调度到其它CPU核上时,这时会使用其它核上的L1、L2缓存,如果有其它应用程序也使用了缓存,这样会降低命中率。
现在服务器一般都是多核的,绑定CPU看起来是一个必然正确的选项,但实际上是有风险的!
在NUMA架构下,操作系统的网络中断程序与REDIS线程可能不在同一个CPU socket上,会导致REDIS线程访问内存变慢,这个时候就需要把网络中断程序与REDIS线程绑定在同一个CPU socket内的不同物理核上,以解决跨CPU socket访问问题。
图片
那绑定CPU还有其它风险吗?
如果绑定了CPU逻辑核后,会导致REDIS子进程都会绑定在这个逻辑核上,这样RDB、AOF等操作都会与REDIS主线程竞争同一个逻辑核。
优化方式为改绑定物理核,或者修改源码使用后台程序及子进程使用其它CPU。