0

0

为什么宝塔面板数据库连接池经常溢出_调整PHP连接持久化与数据库限额

P粉602998670

P粉602998670

发布时间:2026-04-22 00:37:29

|

451人浏览过

|

来源于php中文网

原创

根本原因是PHP持久连接未关闭与MySQL max_connections设置过高叠加导致连接耗尽;需禁用非框架脚本的持久化、合理调低max_connections及wait_timeout,并修复代码中漏掉的mysqli_close()。

为什么宝塔面板数据库连接池经常溢出_调整php连接持久化与数据库限额

不是连接池“溢出”,而是 PHP 持久连接没关 + MySQL max_connections 设太高,两者叠加把连接槽位占死。

PHP 的 pdo_mysqlmysqli 持久连接会复用底层 socket,但不自动释放

宝塔默认启用 mysql.allow_persistent = On(PHP 配置),而大多数 PHP 脚本根本没调用 mysqli_close() 或置空 $pdo。结果是:每个请求结束,连接没断,只是回到连接池“待命”;并发一高,Threads_connected 就卡在高位不降。

  • 检查当前持久连接是否真被复用:执行 SHOW PROCESSLIST;,看大量连接的 CommandSleepTime 持续增长(比如 > 60 秒)
  • 临时禁用持久化:在 /www/server/php/{版本}/etc/php.ini 中设 mysql.allow_persistent = Offmysqli.allow_persistent = Off,然后 bt reload 重载 PHP
  • 不建议全局关——若用了 Laravel / ThinkPHP 等框架,它们内部已管理连接生命周期,此时关反而降低性能;重点查自写脚本或老项目里的裸 mysqli_connect()

MySQL 的 max_connections 不能只看“够不够”,要看“谁在占”

设成 500 看似宽裕,但如果应用层漏关连接,10 个并发就能累积 100+ Sleep 连接,再加定时任务、后台脚本、phpMyAdmin 页面挂着,很快打满。关键不是上限,是连接存活时间。

  • 先确认真实压力:执行 SHOW STATUS LIKE 'Threads_connected';SHOW STATUS LIKE 'Threads_created';,如果后者数值持续上涨(每秒新增 > 1),说明连接频繁重建,大概率是没复用或没关
  • 宝塔里改配置必须写进 [mysqld] 段:路径是 /www/server/mysql/etc/my.cnf,加一行 max_connections = 120(中小站点够用),别写在文件开头或 [client]
  • 别信“调大就安全”——max_connections 每增加 1,MySQL 就多分配一份线程栈内存(默认 256K),1000 连接 ≈ 256MB 额外开销,容易触发 OOM

wait_timeoutinteractive_timeout 是控制“僵尸连接”的实际开关

这两个参数决定空闲连接多久后被 MySQL 主动断开。默认 28800 秒(8 小时),对 Web 场景完全不合理——用户页面关了,PHP 进程却还握着连接不放。

Memo AI
Memo AI

AI音视频转文字及字幕翻译工具

下载

立即学习PHP免费学习笔记(深入)”;

  • my.cnf[mysqld] 段下加:wait_timeout = 60interactive_timeout = 60(单位秒)
  • 注意:这个值不能低于 PHP 的 max_execution_time,否则长查询中途被断连;一般设为 60–180 即可
  • 改完重启 MySQL 生效,之后再查 SHOW VARIABLES LIKE '%timeout%'; 确认是否加载成功

真正卡住的从来不是配置数字,而是代码里那句漏掉的 mysqli_close($conn),或者框架配置里没开连接回收。调参只是兜底,定位并修复连接泄漏点才是根治办法。

相关文章

PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

相关标签:

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

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

WorkBuddy
WorkBuddy

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

通义千问
通义千问

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

Claude
Claude

Anthropic发布的与ChatGPT竞争的聊天机器人

Cursor
Cursor

一个新的IDE,使用AI来帮助您重构、理解、调试和编写代码。

Hermes Agent
Hermes Agent

一位与您共同成长的Agent

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
php文件怎么打开
php文件怎么打开

打开php文件步骤:1、选择文本编辑器;2、在选择的文本编辑器中,创建一个新的文件,并将其保存为.php文件;3、在创建的PHP文件中,编写PHP代码;4、要在本地计算机上运行PHP文件,需要设置一个服务器环境;5、安装服务器环境后,需要将PHP文件放入服务器目录中;6、一旦将PHP文件放入服务器目录中,就可以通过浏览器来运行它。

3344

2023.09.01

php怎么取出数组的前几个元素
php怎么取出数组的前几个元素

取出php数组的前几个元素的方法有使用array_slice()函数、使用array_splice()函数、使用循环遍历、使用array_slice()函数和array_values()函数等。本专题为大家提供php数组相关的文章、下载、课程内容,供大家免费下载体验。

2099

2023.10.11

php反序列化失败怎么办
php反序列化失败怎么办

php反序列化失败的解决办法检查序列化数据。检查类定义、检查错误日志、更新PHP版本和应用安全措施等。本专题为大家提供php反序列化相关的文章、下载、课程内容,供大家免费下载体验。

1597

2023.10.11

php怎么连接mssql数据库
php怎么连接mssql数据库

连接方法:1、通过mssql_系列函数;2、通过sqlsrv_系列函数;3、通过odbc方式连接;4、通过PDO方式;5、通过COM方式连接。想了解php怎么连接mssql数据库的详细内容,可以访问下面的文章。

1310

2023.10.23

php连接mssql数据库的方法
php连接mssql数据库的方法

php连接mssql数据库的方法有使用PHP的MSSQL扩展、使用PDO等。想了解更多php连接mssql数据库相关内容,可以阅读本专题下面的文章。

1777

2023.10.23

html怎么上传
html怎么上传

html通过使用HTML表单、JavaScript和PHP上传。更多关于html的问题详细请看本专题下面的文章。php中文网欢迎大家前来学习。

1403

2023.11.03

PHP出现乱码怎么解决
PHP出现乱码怎么解决

PHP出现乱码可以通过修改PHP文件头部的字符编码设置、检查PHP文件的编码格式、检查数据库连接设置和检查HTML页面的字符编码设置来解决。更多关于php乱码的问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1935

2023.11.09

php文件怎么在手机上打开
php文件怎么在手机上打开

php文件在手机上打开需要在手机上搭建一个能够运行php的服务器环境,并将php文件上传到服务器上。再在手机上的浏览器中输入服务器的IP地址或域名,加上php文件的路径,即可打开php文件并查看其内容。更多关于php相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1432

2023.11.13

phpEnv 多版本 PHP 切换与管理
phpEnv 多版本 PHP 切换与管理

系统讲解 phpEnv 的多版本 PHP 管理能力,涵盖 PHP 5.6、7.4、8.0、8.1、8.2、8.3 等多版本的下载安装与共存配置、不同站点绑定不同 PHP 版本的方法、php.ini 常用参数(内存限制/上传大小/时区/错误显示)的独立调整、PHP 扩展(Redis/Swoole/Xdebug/imagick)的安装与启用,帮助开发者灵活应对多项目多版本的开发需求。

0

2026.04.22

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Xdebug手册
Xdebug手册

共0课时 | 0人学习

如何安装 Composer
如何安装 Composer

共1课时 | 27人学习

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