登录
首页 >  文章 >  php教程

宝塔MySQL内存溢出解决方法大全

时间:2026-04-10 15:24:37 313浏览 收藏

宝塔面板中MySQL频繁因内存溢出自动停止,本质是系统物理内存不足触发Linux内核OOM Killer强制终止进程;本文提供一套系统性解决方案:从合理下调innodb_buffer_pool_size、max_connections等核心内存参数,到启用2GB swap缓解瞬时压力,再到通过systemd设置MemoryLimit与负向OOMScoreAdjust主动管控进程内存上限,同时关闭performance_schema等高开销插件、禁用冗余日志,并指导排查PHP-FPM、恶意脚本等外部内存竞争源——多管齐下,显著提升MySQL在低配服务器上的稳定性与存活率。

宝塔面板下MySQL服务频繁停止提示“内存溢出”怎么办?

如果您在宝塔面板中运行MySQL服务时频繁遇到自动停止,并提示“内存溢出”,则很可能是MySQL进程因系统内存不足被Linux内核的OOM Killer强制终止。以下是针对该问题的多种具体解决方法:

一、调整MySQL最大连接数与缓冲区参数

过高的max_connections、innodb_buffer_pool_size等参数会导致MySQL申请超出物理内存容量的资源,触发OOM Killer干预。需根据服务器实际内存合理下调关键内存相关配置。

1、登录宝塔面板,进入【数据库】→【MySQL管理】→【配置修改】。

2、将innodb_buffer_pool_size值改为不超过服务器总内存的50%(例如2GB内存服务器设为1024M)。

3、将max_connections值从默认151降至64或更低,视实际业务并发量而定。

4、将key_buffer_size设为32M,query_cache_size设为0(MySQL 8.0已移除,若为5.7可设为0以禁用)。

5、点击【保存】并【重启MySQL】服务。

二、启用并配置swap交换分区

当物理内存耗尽时,swap可提供临时内存补充空间,避免OOM Killer立即杀掉MySQL进程。宝塔默认可能未启用swap,需手动创建并激活。

1、通过SSH连接服务器,执行命令:dd if=/dev/zero of=/www/swap bs=1G count=2(创建2GB swap文件)。

2、执行:mkswap /www/swap 初始化swap文件。

3、执行:swapon /www/swap 启用swap。

4、执行:echo "/www/swap swap swap defaults 0 0" >> /etc/fstab 实现开机自动挂载。

5、执行:free -h 确认swap已生效且状态为active。

三、限制MySQL进程内存使用上限

通过systemd对MySQL服务增加内存约束,使其在达到阈值前主动降级而非被OOM Killer强杀,提升服务稳定性。

1、执行命令:systemctl edit mysqld(如服务名为mysql则用mysql)。

2、在打开的编辑器中输入以下内容:

[Service]

MemoryLimit=1.5G

OOMScoreAdjust=-500

3、保存退出后执行:systemctl daemon-reload

4、执行:systemctl restart mysqld 重启服务使配置生效。

四、关闭非必要MySQL插件与日志功能

部分插件(如performance_schema)和全量日志(general_log、slow_query_log)持续占用内存,长期运行易引发累积溢出。

1、进入宝塔【数据库】→【MySQL管理】→【配置修改】。

2、在配置文件末尾添加:performance_schema = OFF

3、注释或删除原有general_log = 1slow_query_log = 1行。

4、若存在log-bin相关配置且无需主从,可一并注释掉log-bin及其配套参数。

5、保存配置并重启MySQL服务。

五、检查并终止占用内存过高的异常进程

MySQL并非唯一内存消耗源,其他进程(如PHP-FPM子进程、Node.js应用、恶意脚本)可能抢占大量内存,间接导致MySQL被杀。

1、执行:top -o %MEM 查看当前内存占用TOP列表。

2、关注RES列数值超过500MB且非mysqld的进程,记录其PID与COMMAND。

3、对可疑进程执行:ps aux --sort=-%mem | head -n 10 进一步确认。

4、若发现异常PHP或Python进程持续高占内存,进入宝塔【网站】→对应站点→【PHP设置】→【性能调整】,降低最大执行进程数。

5、执行:kill -9 PID 终止确认无用的高内存进程(PID替换为实际编号)。

以上就是《宝塔MySQL内存溢出解决方法大全》的详细内容,更多关于的资料请关注golang学习网公众号!

资料下载
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>