一个关于 mysql_connect ,mysql_pconnect 连接时间的问题?

发布于 2022-09-01 17:46:54 字数 131 浏览 20 评论 0

1、mysql_connect 连接后,多长时间会自动释放 ?
2、mysql_pconnect呢,多长时间会自动释放 ?
3、如果使用pdo,是不是和上面情况一样的?
4、配置参数wait_timeout 和连接时间是什么关系?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

就此别过 2022-09-08 17:46:54

假设你使用5个PHP-FPM工作进程跑PHP Web服务.

mysql_connect是短连接,也就是在PHP-FPM工作进程处理完成当前请求后,会自动释放到MySQL的数据库连接.

mysql_pconnect是持久连接,也就是每个PHP-FPM跟MySQL建立连接后,在处理完成当前请求后,并不会释放数据库连接,下一个请求能重用这个数据库连接,从而避免不同请求重复建立数据库连接带来的开销.

有5个PHP-FPM工作进程,就能保持5个到MySQL的持久连接,形成了一一对应的"数据库连接池",但要注意PHP-FPM的进程数pm.max_children不要多于MySQL的最大连接数max_connections(默认151).

show global variables like '%timeout%'; 可见MySQL的wait_timeoutinteractive_timeout的默认值都是28800秒(8小时).PHP-FPM跟MySQL的持久连接,空闲时间超过wait_timeout后,页面再次执行mysql_pconnect会返回"MySQL server has gone away"的Warning信息,这时会重新建立持久连接,并不会影响程序的正常运行,这时可以用@抑制Warning信息的输出.但编写运行在命令行下的PHP CLI程序时,建议不要使用持久连接,建议每次使用时都重新打开和关闭数据库连接,避免数据库连接丢失时导致CLI程序故障的问题.

提一下,mysql_系列函数在PHP7中已经不再支持,建议改用mysqli和pdo_mysql来操作MySQL数据库,mysqli和pdo_mysql同样支持建立持久连接.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文