位置: 编程技术 - 正文

PHP使用php-resque库配合Redis实现MQ消息队列的教程(php使用什么开发工具)

编辑:rootadmin

推荐整理分享PHP使用php-resque库配合Redis实现MQ消息队列的教程(php使用什么开发工具),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:php使用for循环计算1到100的和,php使用for循环实现乘法口诀表,php使用自定义函数编程求半径r为10的圆的周长和面积,php使用oci8扩展连接oracle,php使用for循环计算1到100的和,php使用pdo连接数据库,php使用for循环计算1到100的和,php使用for循环计算1到100的和,内容如对您有帮助,希望把文章链接给更多的朋友!

消息队列处理后台任务带来的问题项目中经常会有后台运行任务的需求,比如发送邮件时,因为要连接邮件服务器,往往需要5-秒甚至更长时间,如果能先给用户一个成功的提示信息,然后在后台慢慢处理发送邮件的操作,显然会有更好的用户体验。

为了实现类似的需求,Web项目中一般的实现方法是使用消息队列(Message Queue),比如MemcacheQ,RabbitMQ等等,都是很著名的产品。

消息队列说白了就是一个最简单的先进先出队列,队列的一个成员就是一段文本。正是因为消息队列实在太简单了,当拿着消息队列时,反而有点无从下手的感觉,因为这仅仅一个发送邮件的任务,就会引申出很多问题:

消息队列只能存储字符串类型的数据,如何将一个发送邮件这样的“任务”,转换为消息队列中的一个“消息”&#; 消息队列只负责数据的存放与进出,本身不能执行任何程序,那么我们要如何从消息队列中一个一个取出数据,再将这些数据转化回任务并执行。 我们无法预知消息队列何时会有数据产生,所以我们的任务执行程序还需要具备监控消息队列的能力,也就是一个常驻后台的守护进程。 一般的Web应用PHP都以cgi方式运行,无法常驻内存。我们知道php还有cli模式,那么守护进程是否能以php cli来实现,效率如何? 当守护进程运行时,Web应用能否与后台守护进程交互,实现开启/杀死进程的功能以及获得进程的运行状态?

Resque对后台任务的设计与角色划分

对以上这些问题,目前为止我能找到的最好答案,并不是来自php,而是来自Ruby的项目Resque,正是由于Resque清晰简单的解决了后台任务带来的一系列问题,Resque的设计也被Clone到Python、php、NodeJs等语言:比如Python下的pyres以及PHP下的php-resque等等,这里有各种语言版本的Resque实现,而在本篇日志里,我们当然要以PHP版本为例来说明如何用php-resque运行一个后台任务,可能一些细节方面会与Ruby版有出入,但是本文中以php版为准。

Resque是这样解决这些问题的:

后台任务的角色划分其实从上面的问题已经可以看出,只靠一个消息队列是无法解决所有问题的,需要新的角色介入。在Resque中,一个后台任务被抽象为由三种角色共同完成:

Job | 任务 : 一个Job就是一个需要在后台完成的任务,比如本文举例的发送邮件,就可以抽象为一个Job。在Resque中一个Job就是一个Class。 Queue | 队列 : 也就是上文的消息队列,在Resque中,队列则是由Redis实现的。Resque还提供了一个简单的队列管理器,可以实现将Job插入/取出队列等功能。 Worker | 执行者 : 负责从队列中取出Job并执行,可以以守护进程的方式运行在后台。

那么基于这个划分,一个后台任务在Resque下的基本流程是这样的:

将一个后台任务编写为一个独立的Class,这个Class就是一个Job。 在需要使用后台程序的地方,系统将Job Class的名称以及所需参数放入队列。 以命令行方式开启一个Worker,并通过参数指定Worker所需要处理的队列。 Worker作为守护进程运行,并且定时检查队列。 当队列中有Job时,Worker取出Job并运行,即实例化Job Class并执行Class中的方法。

至此就可以完整的运行完一个后台任务。

在Resque中,还有一个很重要的设计:一个Worker,可以处理一个队列,也可以处理很多个队列,并且可以通过增加Worker的进程/线程数来加快队列的执行速度。

php-resque的安装需要提前说明的是,由于涉及到进程的开辟与管理,php-resque使用了php的PCNTL函数,所以只能在Linux下运行,并且需要php编译PCNTL函数。如果希望用Windows做同样的工作,那么可以去找找Resque的其他语言版本,php在Windows下非常不适合做后台任务。

以Ubuntu.LTS为例,Ubuntu用apt安装的php已经默认编译了PCNTL函数,无需任何配置,以下指令均为root帐号

安装Redis

安装Composer

使用Composer安装php-resque假设web目录在/opt/htdocs

php-resque的使用1.编写一个Worker其实php-resque已经给出了简单的例子, demo/job.php文件就是一个最简单的Job:

这个Job就是在秒后向STDOUT输出字符Hello!

在Resque的设计中,一个Job必须存在一个perform方法,Worker则会自动运行这个方法。

PHP使用php-resque库配合Redis实现MQ消息队列的教程(php使用什么开发工具)

2.将Job插入队列php-resque也给出了最简单的插入队列实现 demo/queue.php:

在这个例子中,queue.php需要以cli方式运行,将cli接收到的第一个参数作为Job名称,插入名为'default'的队列,同时向屏幕输出刚才插入队列的Job Id。在终端输入:

结果可以看到屏幕上输出:

即Job已经添加成功。注意这里的Job名称与我们编写的Job Class名称保持一致:PHP_Job

3.查看Job运行情况php-resque同样提供了查看Job运行状态的例子,直接运行:

可以看到输出为:

我们刚才创建的Job状态为1。在Resque中,一个Job有以下4种状态:

Resque_Job_Status::STATUS_WAITING = 1; (等待) Resque_Job_Status::STATUS_RUNNING = 2; (正在执行) Resque_Job_Status::STATUS_FAILED = 3; (失败) Resque_Job_Status::STATUS_COMPLETE = 4; (结束)

因为没有Worker运行,所以刚才创建的Job还是等待状态。

4.运行Worker这次我们直接编写demo/resque.php:

可以看到一个Worker至少需要两部分:

可以直接包含Job类文件,也可以使用php的自动加载机制,指定好Job Class所在路径并能实现自动加载包含Resque的默认Worker: bin/resque在终端中运行:

前面的QUEUE部分是设置环境变量,我们指定当前的Worker只负责处理default队列。也可以使用

来处理所有队列。

运行后输出为

用ps指令检查一下:

可以看到有一个php的守护进程已经在运行了

再使用之前的检查Job指令

2分钟后可以看到

任务已经运行完毕,同时屏幕上应该可以看到输出的Hello!

PHP上传图片类显示缩略图功能 有缩略图功能但是感觉不全面,而且有点问题,继续学习,将来以后修改下formaction="php$_SERVER['PHP_SELF'];"enctype="multipart/form-data"method="post"inputtype="text"name="

eclipse php wamp配置教程 eclipse+php+wamp配置入门教程,具体内容如下想要学习php,被各种配置虐了一遍。现在提供一个最为简单的php配置。希望给第一次学习PHP的朋友,一些帮助

Yii2 ActiveRecord多表关联及多表关联搜索的实现 Yii的ActiveRecord是与数据库打交道的类,也即MVC中的M(模型层),也是ORM的O(Object)。一个老生常谈的问题。最近通过群里的反馈,觉得很多人还是没有

标签: php使用什么开发工具

本文链接地址:https://www.jiuchutong.com/biancheng/296429.html 转载请保留说明!

上一篇:Thinkphp批量更新数据的方法汇总(thinkphp批量导入数据)

下一篇:PHP上传图片类显示缩略图功能(php上传图片并显示)

  • 销售收入不含税怎么计算增值税额
  • 煤炭企业生产能力
  • 收到汇算清缴退款会计分录
  • 每月长摊金额如何分摊
  • 怎么知道对方的支付宝账号
  • 公司承担个人社保部分福利
  • 单位发放中秋月饼价值有规定吗
  • 事业单位职工福利费计提标准和使用
  • 售后回租的实际操作流程
  • 减免的增值税如何账务处理
  • 发票是不是都一样
  • 增值税专用发票有效期是多长时间
  • 提供物业管理服务税率
  • 房地产的出租行为属于土地增值税征收范围吗
  • 土地增值税的纳税人是在我国境内
  • 增值纳税人类别怎么选
  • 企业的其他业务收入
  • 固定资产的残值怎么算出来的
  • 美团扣点怎么做凭证
  • 房地产中介公司排名
  • 期货手续费会计分录
  • 没有原始凭证可以审计吗
  • 如何停止win11
  • bios里硬盘是哪个
  • 财政拨款事业单位和全额事业单位
  • 车辆的代驾费应该怎么收
  • vue打开窗口
  • linux系统网络日志
  • 现金解款单怎么读
  • 审核原始凭证应注意
  • 会计差错更正账务处理会计分录
  • 简单解决微信文案的方法
  • 图书发票怎么报销的
  • php获取浏览器ua
  • 发票作废发票怎么处理
  • css中清除浮动
  • centos7安装keepalived
  • 我的年终总结怎么写
  • php字符串型数据的定义方式
  • 公司注销实收资本退回需要交税吗
  • 发票货物或应税劳务名称怎么填写
  • sqlserver2008误操作数据
  • mysql备份方式有哪些
  • vue生命周期钩子函数
  • vue使用高德地图闪白屏
  • 预收款销售商品如何与业务员对账
  • 用友t3怎么结转本年利润
  • 营改增后建筑企业如何正确开具发票
  • SqlServer 2005 T-SQL Query 学习笔记(2)
  • 当月销售次月开票怎么做账
  • 小规模纳税人免税额度是多少
  • 会计科目长期待摊费用
  • 核销单取消后出口收汇流程
  • 私车公用费用报销
  • 维修费成本怎么结转
  • 公司账户没有钱怎么发工资
  • 公司给员工结婚红包
  • 主营业务成本可以设明细科目吗
  • 从增值税抵扣进项怎么算
  • 申报高新技术企业专利有什么要求
  • 哪些企业可以减免企业所得税
  • 软件公司购买软件用于研发
  • 残疾人就业保障金征收使用管理办法
  • phpmyadmin配置文件
  • ubuntu系统虚拟机安装教程
  • 如何清理注册表的垃圾文件
  • winxp关机立马自动重启
  • windows7文件夹选项在哪里
  • win7专用字符编辑程序
  • opware12.exe - opware12进程是什么文件 有什么用
  • win7一直处于开机界面
  • Win10控制面板打不开
  • 电子书进不去系统原因
  • 计算机中丢失opencv_core249.dll
  • settimeout和setinterval在安卓机无效
  • javascript怎么学
  • jquery打开文件对话框
  • 事件的分发与传播的关系
  • 孵化企业税收优惠
  • 云南省代理记账管理实施办法
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设