详解PHP使用gearman进行异步的邮件或短信发送操作
本文实例讲述了PHP使用gearman进行异步的邮件或短信发送操作。分享给大家供大家参考,具体如下:
成都创新互联长期为上千余家客户提供的网站建设服务,团队从业经验10年,关注不同地域、不同群体,并针对不同对象提供差异化的产品和服务;打造开放共赢平台,与合作伙伴共同营造健康的互联网生态环境。为雨花台企业提供专业的网站设计制作、做网站,雨花台网站改版等技术服务。拥有十年丰富建站经验和众多成功案例,为您定制开发。一、准备工作
1、为了防止,处理业务途中出现的宕机,请配置好gearman的持久化方式。
2、使用gearmanManager来管理我们的worker脚本,方便测试。
二、编写测试脚本
sendEmail.php
代码如下:
workload(), true); //这里模拟处理过程 //具体的业务,这里应该是请求发送邮件的接口,这里只做演示 sleep(1); echo "workId: {$workId} 发送 {$data['email']} 成功\\n"; }
client.php
代码如下:
addServer('127.0.0.1', 4730); $cnt = 5000; $ret = array(); //循环发送5000条邮件 for($i = 0; $i < $cnt; ++$i) { //doBackground异步,返回提交任务的句柄 $ret[$i] = $client->doBackground('sendEmail', json_encode(array( 'email' => "{$i}@qq.com", 'title' => "邮件标题{$i}", 'body' => "我是内容{$i}", ))); }
三、修改gearmanManager中配置信息
我的gearmanManager是安装在/data/GearmanManager/下
> vi /data/GearmanManager/etc/GearmanManager.ini
添加如下信息,我们为sendEmail启动五个进程
[sendEmail] ;指定5个进程 dedicated_count=5 ;5个进程都只做sendEmail工作 dedicated_only=1
四、启动gearman
> gearmand -d -q mysql \\ --mysql-host=192.168.1.100 \\ --mysql-port=3306 \\ --mysql-user=gearman \\ --mysql-password=123456 \\ --mysql-db=gearman \\ --mysql-table=gearman_queue &
五、启动gearmanManager
> cd /data/GearmanManager > ./bin/pecl_manager.php -c /data/GearmanManager/etc/GearmanManager.ini -vvv
六、运行client.php
> /data/php56/bin/php /data/client.php
当我们对pecl_manager.php进行ctrl+c时,强行关闭worker,client.php那边仍可正常的发送请求,不过数据都被保存在了mysql中。
当我们重新把worker启动时,gearman会重新载入没有处理的进行处理。
我的mysql是装在主机的,虚拟机里装了gearman,如果有朋友发现gearman无法连接mysql,可暂时关闭win10防火墙,和开启win10被ping的回显。
本文名称:详解PHP使用gearman进行异步的邮件或短信发送操作
标题来源:http://pwwzsj.com/article/cjocjj.html