0

0

Linux系统下针对数据库进程的透明大页THP优化建议

冰川箭仙

冰川箭仙

发布时间:2026-03-19 09:11:33

|

309人浏览过

|

来源于php中文网

原创

数据库场景应禁用透明大页(THP),因其引发内存延迟升高、周期性卡顿等问题;可通过临时/永久方式关闭,或对进程单独禁用,并验证AnonHugePages为0及延迟指标改善。

linux系统下针对数据库进程的透明大页thp优化建议

Linux系统中,透明大页(THP, Transparent Huge Pages)默认启用可能对数据库类进程(如MySQL、PostgreSQL、Oracle等)造成性能下降,主要表现为内存延迟升高、周期性卡顿、缓冲区分配抖动等问题。根本原因在于THP的后台合并(khugepaged)与数据库频繁的小页内存分配/释放行为冲突,导致锁竞争和内存碎片化。

确认THP当前状态

执行以下命令查看系统是否启用THP:

cat /sys/kernel/mm/transparent_hugepage/enabled

输出通常为[always] madvise never(表示默认启用)或always [madvise] never(需应用显式调用才启用)。数据库场景应避免always模式。

MedPeer自然科学基金
MedPeer自然科学基金

科研申报与成果分析的智能数据引擎

下载

推荐关闭THP(生产环境标准做法)

对运行MySQL、PostgreSQL、MongoDB、Redis等数据库服务的服务器,建议永久禁用THP:

  • 临时关闭(立即生效,重启失效):
    echo never > /sys/kernel/mm/transparent_hugepage/enabled
    echo never > /sys/kernel/mm/transparent_hugepage/defrag
  • 永久关闭(写入启动配置):
    /etc/rc.local(传统SysV)或/etc/systemd/system/disable-thp.service(systemd)中添加上述两行;
    或通过内核启动参数:在/etc/default/grubGRUB_CMDLINE_LINUX中追加transparent_hugepage=never,再运行update-grub && reboot

替代方案:仅对数据库进程禁用THP(进阶控制)

若因其他服务依赖THP而不能全局关闭,可对数据库进程单独禁用:

  • MySQL:在my.cnf[mysqld]段添加:
    innodb_use_sys_malloc = 1
    malloc_lib = /usr/lib64/libjemalloc.so.2(配合jemalloc,并确保其编译时启用--with-lg-page=12
  • PostgreSQL:启动前设置环境变量:
    export MALLOC_CONF="thp:never"(需使用jemalloc);或在postgresql.conf中设shared_preload_libraries = 'pg_jemalloc'
  • 通用方式(需glibc ≥ 2.29):在启动脚本中加入
    echo never > /proc/self/transparent_hugepage/enabled(仅对当前进程及其子进程生效)

验证与监控要点

优化后需确认效果:

  • 检查进程内存页大小:
    grep -i huge /proc/<pid>/smaps | grep "mm\|AnonHugePages" —— AnonHugePages应长期为0
  • 观察延迟指标:
    使用perf stat -e major-faults,minor-faults -p <pid>对比优化前后缺页中断频率
  • 数据库自身指标:
    MySQL关注Innodb_buffer_pool_wait_freeThreads_connected抖动;PostgreSQL关注bgwriter buffers written突增和checkpoint_write_time异常延长

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
服务器是什么
服务器是什么

服务器是一种计算机硬件设备或软件程序,它具有强大的计算和存储能力,用请求、存储数据和提供服务。它在互联网中着关重要的作用,为用户提供各种服务和资源。本专题为大家提供服务器相关的文章、下载、课程内容,供大家免费下载体验。

191

2023.08.15

连接apple id服务器时出错
连接apple id服务器时出错

连接apple id服务器时出错的原因包括网络连接问题、服务器问题、Apple ID账户问题、设备问题、防火墙或安全软件问题、时间和日期设置问题、Apple服务器维护等。本专题为大家提供apple id相关的文章、下载、课程内容,供大家免费下载体验。

444

2023.09.08

搭建互联网服务器
搭建互联网服务器

搭建互联网服务器需要:1、选择合适的硬件和操作系统,第一步是选择合适的硬件和操作系统;2、安装和配置操作系统,是搭建互联网服务器的关键步骤;3、安装和配置服务器软件,是搭建互联网服务器的下一步,常见的服务器软件包括Apache、Nginx、Tomcat等;4、配置防火墙和安全性,是搭建互联网服务器的重要步骤;5、域名解析和配置,是搭建互联网服务器的最后一步。

217

2023.09.19

如何查看服务器状态
如何查看服务器状态

查看服务器状态的方法有使用命令行工具、图形界面工具、监控工具、日志文件和远程管理工具等。本专题为大家提供服务器状态相关的文章、下载、课程内容,供大家免费下载体验。

184

2023.10.09

服务器域名转接慢怎么解决
服务器域名转接慢怎么解决

服务器域名转接慢的解决办法有DNS优化、服务器优化、CDN加速、前端优化和网络优化等。本专题为大家提供服务器相关的文章、下载、课程内容,供大家免费下载体验。

75

2023.10.17

服务器评测软件
服务器评测软件

服务器评测软件有PassMark Software、CPU-Z、GPU-Z、CrystalDiskMark、IOmeter、JMeter、LoadRunner、Apache Bench等等。详细介绍:1、PassMark Software是一款综合性的服务器性能测试软件,可以评估服务器在各种负载条件下的性能;2、CPU-Z是一款可以提供服务器CPU详细信息的软件等等。

99

2023.10.17

如何开启TFTP服务器
如何开启TFTP服务器

开启TFTP服务器的步骤包括选择TFTP服务器软件、下载和安装软件、配置TFTP服务器以及启动和测试服务器等。本专题为大家提供服务器相关的文章、下载、课程内容,供大家免费下载体验。

121

2023.10.18

服务器负载不兼容怎么解决
服务器负载不兼容怎么解决

解决方法:1、增加服务器资源;2、负载均衡;3、优化应用程序;4、增加缓存机制;5、分布式架构;6、限流和熔断;7、自动化扩容。想知道更详细服务器负载不兼容的解决方法,可以访问本专题下面的文章。

122

2023.10.20

bootstrap安装教程
bootstrap安装教程

本专题整合了bootstrap安装相关教程,阅读专题下面的文章了解更多详细操作教程。

22

2026.03.18

热门下载

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

精品课程

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

共48课时 | 10.9万人学习

Git 教程
Git 教程

共21课时 | 4.3万人学习

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

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