Redis 性能优化 —— 关闭 THP

文章目录

        • 一、场景描述
        • 二、问题分析
        • 三、解决方案

一、场景描述

  • 启动 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.
    

二、问题分析

  1. 从提示上可以看出 Redis 建议修改 Transparent Huge Pages(THP) 的相关配置

  2. Linux kernel 在 2.6.38 的版本中新增了 THP 的特性,支持大内存页(2MB)分配,默认开启。

  3. 当开启 THP 时会降低 fork 子进程的速度,但是 fork 操作之后,每个内存页从原来 4KB 变为 2MB,会大幅增加重写期间父进程内存消耗

  4. 同时每次写命令引起的复制内存也单位放大了 512 倍,会拖慢写操作的时间,导致大量写操作慢查询,例如:简单的 incr、set 命令也会出现在慢查询中

三、解决方案

  1. 基于现有的警告提醒和内存分析,建议关闭 THP

  2. 操作步骤

    # CentOS 的操作方式
    echo never > /sys/kernel/mm/transparent_hugepage/enabled
    
    # Red Hat6或更高的操作方式
    echo never > /sys/kernel/mm/redhat_transparent_hugepage/enabled
    
    # 重启服务器
    reboot
    

你可能感兴趣的:(redis,数据库,缓存)