首页 > 后端开发 > php教程 > PHP cli while(true) sleep(60) mysql

PHP cli while(true) sleep(60) mysql

WBOY
发布: 2016-06-06 20:34:51
原创
1631 人浏览过

假设有一个 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 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 服务器的压力?

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

相关标签:
来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板