MySQL启用large-pages失败主因是内核未配vm.nr_hugepages、limits.conf未设memlock、systemd覆盖ulimit或mysqld非root/CAP_IPC_LOCK权限启动;需依次配置sysctl、limits、service文件,并在[mysqld]段写large-pages(无等号),再验证pmap和INNODB STATUS。MySQL 启用 large-pages 失败的常见报错直接启动 mysqld 时看到 Failed to set up huge pages 或 Cannot allocate memory for huge pages,基本是内核没配、权限不足、或 MySQL 用户没被授权访问大页。不是配置文件写对了就能跑起来。Linux 默认不启用透明大页(transparent_hugepage),而 MySQL large-pages 要求的是显式大页(hugetlbpage),两者不能混用mysqld 进程必须以 root 或有 CAP_IPC_LOCK 权限的用户启动,普通 mysql 用户默认锁不住大页内存内核参数 vm.nr_hugepages 必须提前分配,且值要 ≥ MySQL 预期申请量(比如 2MB 页 × 1024 = 2GB)配置 /etc/sysctl.conf 和 /etc/security/limits.conf这俩文件漏改一个,large-pages 就会静默退回到普通页------不会报错,但 SHOW VARIABLES LIKE 'large_pages' 显示 ON,实际没生效。在 /etc/sysctl.conf 加:vm.nr_hugepages = 1024(按需调整,单位是 2MB 页)运行 sudo sysctl -p 生效,再用 cat /proc/meminfo | grep Huge 确认 HugePages_Total 不为 0在 /etc/security/limits.conf 加两行:mysql soft memlock unlimited 和 mysql hard memlock unlimited(假设 MySQL 服务用户是 mysql)重启 mysqld 前,确保它由 systemd 启动时未覆盖 ulimit:检查 /usr/lib/systemd/system/mysqld.service 是否含 LimitMEMLOCK=infinitymy.cnf 中开启 large-pages 的关键写法large-pages 是 mysqld 启动时一次性申请的全局行为,不能动态 SET,也不支持只对 buffer pool 开启。配置写错位置或加了引号就无效。 通义听悟 阿里云通义听悟是聚焦音视频内容的工作学习AI助手,依托大模型,帮助用户记录、整理和分析音视频内容,体验用大模型做音视频笔记、整理会议记录。
相关推荐
HHHHH1010HHHHH2 小时前
HTML怎么创建评论区域_HTML嵌套评论语义结构【详解】Absurd5872 小时前
C#怎么模拟键盘按键输入_C#如何实现自动化脚本【教程】甘露寺2 小时前
【LangGraph 2026 核心原理解析】大模型 Tool Calling 机制与使用最佳实践全解Chasing__Dreams2 小时前
Redis--基础知识点--29--Redis瓶颈amIZ AUSK2 小时前
实操解决Navicat连接postgresql时出现‘datlastsysoid does not exist‘报错的问题gmaajt2 小时前
Golang怎么读取环境变量_Golang如何用os.Getenv获取系统环境变量【基础】久绊A2 小时前
Python环境配置错误导致部署失败案例2601_949194262 小时前
Redis的安装教程(Windows+Linux)【超详细】傻啦嘿哟2 小时前
Python 文件批量处理:重命名/备份/同步运维实战指南