博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
使用gearman进行异步的邮件或短信发送
阅读量:6957 次
发布时间:2019-06-27

本文共 1426 字,大约阅读时间需要 4 分钟。

一、准备工作

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的回显。

 

转载于:https://www.cnblogs.com/jkko123/p/6505274.html

你可能感兴趣的文章
你可能不知道的 css 内容块
查看>>
SourceTree 教程文档(安装并设置SourceTree)
查看>>
solr6.6教程-基础环境搭建(二)
查看>>
C# WPF 低仿网易云音乐(PC)Banner动画控件
查看>>
提交自己的包到bower、npm中
查看>>
详解 JavaScript 的私有变量
查看>>
网站建设在“互联网+”时代的发展趋势
查看>>
脚本语言不行?JavaScript 重写 Office 365 已进入尾声
查看>>
日志框架 - 基于spring-boot - 设计
查看>>
R语言基础操作①
查看>>
安装 PrestaShop 1.6 - 关于快速安装指南
查看>>
ecshop中ajax的调用原理
查看>>
速查笔记(Linux Shell编程<上>)
查看>>
更换手机设备时如何同步迁移便签内容?
查看>>
Linux进程间通信之共享内存
查看>>
模拟返回的后台数据实现统计图
查看>>
《Linux命令行与shell脚本编程大全》第二十六章 一些有意思的脚本
查看>>
设置文字旋转角度
查看>>
Spring_DI_XML_02
查看>>
uCos-III移植到STM32F10x
查看>>