0

0

Linux transparent hugepage 的 always / madvise / never 模式对 Redis 的影响

舞夢輝影

舞夢輝影

发布时间:2026-02-28 16:34:03

|

221人浏览过

|

来源于php中文网

原创

应禁用 thp,设为 never;因 redis 的 fork 和 jemalloc 与 thp 冲突,导致 fork 延迟、rss 虚高、oom 及 active-defrag 失效,需通过 systemd 或 rc.local 永久配置并验证生效。

linux transparent hugepage 的 always / madvise / never 模式对 redis 的影响

Redis 启动报 WARNING: The TCP backlog setting of 511 cannot be enforced 或内存分配慢,可能和 THP 有关

Linux 的 transparent hugepage(THP)默认开启 always 模式时,内核会主动合并小页为 2MB 大页。Redis 的内存分配模式(尤其是 jemalloc)和 fork() 行为对大页不友好——它会导致 fork 延迟飙升、RSS 内存虚高、甚至触发 OOM killer。

常见现象包括:

  • Redis 日志里反复出现 WARNING: You have Transparent Huge Pages (THP) support enabled in your kernel
  • INFO memory 显示 mem_allocator 是 jemalloc,但 used_memory_rss 远大于 used_memory
  • 主从全量同步或 RDB save 期间,redis-server 进程卡住数秒,系统负载突增

这不是 Redis 配置问题,而是内核内存管理策略与 Redis 工作方式的冲突。解决方向很明确:关掉 THP 的自动合并行为。

/sys/kernel/mm/transparent_hugepage/enabled 三个值的实际效果差异

always:内核强制对所有匿名内存区域尝试合并为 huge page,Redis 的堆、fork 出的子进程内存都会被卷入,最危险;

madvise:只对显式调用 madvise(..., MADV_HUGEPAGE) 的内存生效——Redis 默认不这么干,所以等效于关闭;

never:彻底禁用 THP,连 madvise 请求都拒绝,最保守也最安全。

生产环境推荐直接设为 never,别贪 madvise 那点理论收益。因为:

PhotoAid Image Upscaler
PhotoAid Image Upscaler

PhotoAid出品的免费在线AI图片放大工具

下载
  • Redis 没有在关键路径上标记 MADV_HUGEPAGEmadvise 实际不起作用
  • 某些内核版本(如 CentOS 7.6+ 的 3.10.0-1127)在 madvise 下仍会 fallback 到 always 行为
  • never 对性能无负面影响,反而让 RSS 和实际使用内存更接近

如何永久禁用 THP(避免重启后恢复 always

临时改只是治标:echo never > /sys/kernel/mm/transparent_hugepage/enabled,但重启就丢。必须写进启动流程。

不同发行版写法略有区别,核心是确保在 Redis 启动前执行:

  • Systemd 系统(Ubuntu 16.04+/CentOS 7+):新建 /etc/systemd/system/disable-thp.service,在 [Service] 下加 ExecStart=/bin/sh -c 'echo never > /sys/kernel/mm/transparent_hugepage/enabled',然后 systemctl enable disable-thp
  • 旧 SysVinit(CentOS 6):在 /etc/rc.local 里加同一行 echo never > /sys/kernel/mm/transparent_hugepage/enabled,并确保文件有执行权限
  • 注意:不能写进 /etc/default/grubtransparent_hugepage=never 参数——这个内核参数在较新内核(>=4.12)已废弃,无效

验证是否生效:cat /sys/kernel/mm/transparent_hugepage/enabled 输出应为 [never],中括号包住的那个值才是当前生效项。

Redis 6.0+ 开启 active-defrag 时更要关 THP

内存碎片整理(activedefrag)依赖频繁的 mremapmmap 调用,而 THP 会让这些系统调用变慢甚至失败。开启 defrag 后若 THP 仍为 always,会出现:

  • INFO statsactive_defrag_running 长期为 1,但 mem_fragmentation_ratio 不降反升
  • 日志里出现 Failed to allocate memory for defrag 类错误
  • Redis 主进程 CPU 使用率异常升高,但吞吐没提升

这不是配置错了,是 THP 干扰了内存重映射路径。哪怕你开了 active-defrag,也得先确保 THP 是 never——否则碎片整理根本跑不起来。

THP 的影响藏得深,不报错、不 crash,只悄悄拖慢 fork、涨 RSS、卡 defrag。检查它,比调 maxmemory-policytimeout 更优先。

相关文章

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

429

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

599

2023.08.10

default gateway怎么配置
default gateway怎么配置

配置default gateway的步骤:1、了解网络环境;2、获取路由器IP地址;3、登录路由器管理界面;4、找到并配置WAN口设置;5、配置默认网关;6、保存设置并退出;7、检查网络连接是否正常。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

233

2023.12.07

常用的数据库软件
常用的数据库软件

常用的数据库软件有MySQL、Oracle、SQL Server、PostgreSQL、MongoDB、Redis、Cassandra、Hadoop、Spark和Amazon DynamoDB。更多关于数据库软件的内容详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1000

2023.11.02

内存数据库有哪些
内存数据库有哪些

内存数据库有Redis、Memcached、Apache Ignite、VoltDB、TimesTen、H2 Database、Aerospike、Oracle TimesTen In-Memory Database、SAP HANA和ache Cassandra。更多关于内存数据库相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

665

2023.11.14

mongodb和redis哪个读取速度快
mongodb和redis哪个读取速度快

redis 的读取速度比 mongodb 更快。原因包括:1. redis 使用简单的键值存储,而 mongodb 存储 json 格式的数据,需要解析和反序列化。2. redis 使用哈希表快速查找数据,而 mongodb 使用 b-tree 索引。因此,redis 在需要高性能读取操作的应用程序中是一个更好的选择。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

500

2024.04.02

redis怎么做缓存服务器
redis怎么做缓存服务器

redis 作为缓存服务器的答案:redis 是一款开源、高性能、分布式的键值存储,可作为缓存服务器使用。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

410

2024.04.07

redis怎么解决数据一致性
redis怎么解决数据一致性

redis 提供了两种一致性模型,以维护副本数据一致性:强一致性 (sync) 确保写操作仅在复制到所有从节点后才完成;最终一致性 (async) 则在主节点上写操作后认为已完成,牺牲一致性换取性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

406

2024.04.07

Golang 测试体系与代码质量保障:工程级可靠性建设
Golang 测试体系与代码质量保障:工程级可靠性建设

Go语言测试体系与代码质量保障聚焦于构建工程级可靠性系统。本专题深入解析Go的测试工具链(如go test)、单元测试、集成测试及端到端测试实践,结合代码覆盖率分析、静态代码扫描(如go vet)和动态分析工具,建立全链路质量监控机制。通过自动化测试框架、持续集成(CI)流水线配置及代码审查规范,实现测试用例管理、缺陷追踪与质量门禁控制,确保代码健壮性与可维护性,为高可靠性工程系统提供质量保障。

0

2026.02.28

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 9.9万人学习

Git 教程
Git 教程

共21课时 | 3.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号