Redis是否需要绑定CPU?

网友投稿 660 2023-06-05

Redis是否需要绑定CPU?

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。

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:99%的人会踩MySQL这个坑!
下一篇:MyBatis原生批量插入的坑与解决方案!
相关文章