PHP cli while(true) sleep(60) mysql
PHP中文网
PHP中文网 2017-04-10 15:35:55
[PHP讨论组]

假设有一个 php cli 文件,每2分钟运行一次执行 mysql 数据写入操作。

如果用 corntab 或者 mq 的话,每一次执行都要

  1. 建立 mysql 连接
  2. 执行批量写入
  3. php 手动结束 mysql 连接(实际上 mysql 连接并没有结束,只是 php 释放而已)
  4. php 结束运行 释放内存
  5. 此时 mysql connection 处理 sleep 状态
  6. 2分种后,再次执行 1 ~ 5

脚本每 2 分钟一次,24小时下来,mysql 就会产生大量的 sleep connection,就算优化了 mysql 的 wait_timeout thread_cache_size 这些参数也没有用是吗?

如果是 while(true) 的话,php 使用 pconnect 只建立了一个 mysql 连接,只要 php 进程在运行就永不释放 mysql connection 对吗?

这样是不是就能节省 mysql 连接数,从而减少 mysql 服务器的压力?

PHP中文网
PHP中文网

认证0级讲师

全部回复(2)
ringa_lee

一个 cli 2分钟运行一次又没并发,只需要看数据库读的操作有没有如果有就做读写分离就解决啦。优化 php 的 connection pooling 这个太难了。

高洛峰

是的,但是mysql会根据配置,默认8小时后强制断开连接!

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

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