线程池 - 想用php发邮件然后记录发送结果,目前用的redis,用一个脚本执行发送和记录操作,很慢,有什么更好的方法吗

php中文网
发布: 2016-09-27 14:18:11
原创
1185人浏览过

目前是用的一个php脚本,执行请求外部接口发邮件,然后等邮件返回,得到处理结果,然后往自己的数据库记录发送结果。。
一个小时大概能处理2w条,太慢了。。

老板说用线程池来做,我现在又是一脸懵逼。。不太懂具体的做法,有大神能说一下大概的过程吗?是用Thread这个扩展吗?

回复内容:

目前是用的一个php脚本,执行请求外部接口发邮件,然后等邮件返回,得到处理结果,然后往自己的数据库记录发送结果。。
一个小时大概能处理2w条,太慢了。。

老板说用线程池来做,我现在又是一脸懵逼。。不太懂具体的做法,有大神能说一下大概的过程吗?是用Thread这个扩展吗?

刚好做过类似的事情,可以提点意见。
2w/h ≈ 5.55 QPS,的确不高。

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

如果按你老板的思路,一个单线程的脚本执行慢,那就多几个。那么你需要的是 pthreads 扩展(多线程),或者直接开多个进程处理(pcntl扩展甚至直接 exec 都可以)。

话袋AI笔记
话袋AI笔记

话袋AI笔记, 像聊天一样随时随地记录每一个想法,打造属于你的个人知识库,成为你的外挂大脑

话袋AI笔记 47
查看详情 话袋AI笔记

但从你的需求看,使得占用处理时间的主要内容是外部 IO 等待。可以考虑使用并发同时发送多封邮件(比如 multi_curl),或者异步发送邮件(比如 curl 的 async),或者整体使用个异步服务(比如 swoole 扩展)

数据表增加一个字段 process_id
插入数据库记录的时候随机给 process_id 赋值 mt_rand(1,10)
开启 10 个 PHP 脚本,
第一个脚本处理 process_id 为 1 的记录:select * from send_email_list where process_id=1 and status=0
第二个脚本处理 process_id 为 2 的记录:select * from send_email_list where process_id=2 and status=0
这样同时 10 个进程处理,这是最简单直接的方法,让你的处理速度直接提升 10 倍。

多线程,multi_curl 并发, swoole 异步都是可行解决方案。但上面的方案只需要在现有基础上进行简单改动便可以实现,可能更加适合题主。

用nodejs来做后台发送邮件服务

相关标签:
php
PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

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

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

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