PHP   发布时间:2022-04-09  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了PHP使用php-resque库配合Redis实现MQ消息队列的教程大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。

消息队列处理后台任务带来的问题

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

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

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

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

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

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

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

后台任务的角色划分

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

  • Job | 任务 : 一个Job就是一个需要在后台完成的任务,比如本文举例的发送邮件,就可以抽象为一个Job。在Resque中一个Job就是一个Class。
  • Queue | 队列 : 也就是上文的消息队列,在Resque中,队列则是由redis实现的。Resque还提供了一个简单的队列管理器,可以实现将Job插入/取出队列等@L_696_26@。
  • 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下非常不适合做后台任务。

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

安装redis


大佬总结

以上是大佬教程为你收集整理的PHP使用php-resque库配合Redis实现MQ消息队列的教程全部内容,希望文章能够帮你解决PHP使用php-resque库配合Redis实现MQ消息队列的教程所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。