一、场景描述
-
启动
Redis
集群过程中,会看到如下警告:WARNING you have Transparent Huge Pages (THP) support enabled in your kernel. This will create latency and memory usage issues with Redis. To fix this issue run the command 'echo never > /sys/kernel/mm/transparent_hugepage/enabled' as root, and add it to your /etc/rc.local in order to retain the setting after a reboot. Redis must be restarted after THP is disabled.
二、问题分析
-
从提示上可以看出
Redis
建议修改Transparent Huge Pages(THP)
的相关配置 -
Linux kernel
在 2.6.38 的版本中新增了THP
的特性,支持大内存页(2MB)分配,默认开启。 -
当开启
THP
时会降低fork
子进程的速度,但是fork
操作之后,每个内存页从原来 4KB 变为 2MB,会大幅增加重写期间父进程内存消耗 -
同时每次写命令引起的复制内存也单位放大了 512 倍,会拖慢写操作的时间,导致大量写操作慢查询,例如:简单的 incr、set 命令也会出现在慢查询中
三、解决方案
-
基于现有的警告提醒和内存分析,建议关闭
THP
-
操作步骤
# CentOS 的操作方式 echo never > /sys/kernel/mm/transparent_hugepage/enabled # Red Hat6或更高的操作方式 echo never > /sys/kernel/mm/redhat_transparent_hugepage/enabled # 重启服务器 reboot