redis的优化 cpu与redis进程的绑定

记录地址: https://www.jianshu.com/p/4cefb57459dd

“我们不能任由操作系统负载均衡,因为我们 自己更了解自己的程序,所以,我们可以手动地为其分配CPU核,而不会过多地占用CPU0,或是让我们关键进程和一堆别的进程挤 在一起。”。
在文章中提到了 Linux下的一个工具,taskset,可以设定单个进程运行的CPU。
以下均以redis-server 举例。
1)显示进程运行的CPU

命令taskset -p 21184

显示结果:

pid 21184’s current affinity mask: ffffff

注:21184是redis-server运行的 pid

显示结果的ffffff实际上是二进制24个低位均为1的bitmask,每一个1对应于1个CPU,表示该进程在24个CPU上运行

2)指定进程运行在某个特定的CPU上

命令taskset -pc 3 21184

显示结果:

pid 21184’s current affinity list: 0-23
pid 21184’s new affinity list: 3

注:3表示CPU将只会运行在第4个CPU上(从0 开始计数)。

3)进程启动时指定CPU

命令taskset -c 1 ./redis-server …/redis.conf

影响 Redis 性能的因素之一
CPU 是一个重要的影响因素,由于是单线程模型,Redis 更喜欢大缓存快速 CPU, 而不是多核
在多核 CPU 服务器上面,Redis 的性能还依赖 NUMA 配置和 处理器绑定位置。 最明显的影响是 redis-benchmark 会随机使用 CPU 内核。为了获得精准的结果,
需要使用固定处理器工具(在 Linux 上可以使用 taskset)。 最有效的办法是将客户端和服务端分离到两个不同的 CPU 来高校使用三级缓存

你可能感兴趣的:(Redis)