欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  后端开发

PHP cli while(true) sleep(60) mysql

程序员文章站 2022-04-23 18:45:37
...
假设有一个 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 这个太难了。

相关标签: mysql php