文档章节

php-resque 极简php消息队列

inuxor
 inuxor
发布于 2016/03/11 17:29
字数 1112
阅读 1104
收藏 5

安装

  • 首先这货需要在linux下跑,非得用windows就别看了,也不是不能装,费劲且性能渣
  • 得有composer,嫌慢的也拉倒吧,别看了,本文不介绍没有composer怎么办
  • 安装composer也不是本文要点,在ubuntu(其实为了不折腾QQ我装的是deepin)中就是一行命令
  • php版本要高一点,5.4以下也别看了
  • 该环境php是apt装的,所以一切无阻碍,如果是编译安装可能不会这么顺畅

安装composer

sudo apt-get install composer

安装redis

redis是个数据库,nosql。不是废话,因为有人的确不知道

sudo apt-get install redis-server

还得有git

sudo apt-get install git

真正的安装

cd /your/www/path
git clone git://github.com/chrisboulton/php-resque.git
cd php-resque
composer install

不出意外的话能安装成功,抽风就多试几次,包不大,可忍受

demo

网上有些demo,都是抄的同一个博文,尔等能找到这里很可能是那一篇看了觉得不大对头。 composer安装的包里面有demo,里面的代码也TM坑的很。所以还是看我这篇。。。。

首先咱们写个简单的job

job,工作,就是碎催,接到消息之后干活的,好,定义明确了

<?php
// job.php 放在demo目录里面,原有的那个删了算球

class TestJob
{
	public function perform()
	{
        echo $this->args['name'];
	}
}

再写个脚本往队列里写消息

<?php
// demo/quere.php 注意,这个是个命令行版,需要在shell中运行,也可以自己写个浏览器里能跑的
// 功能,往队列里写一些装逼犯的名字
if(empty($argv[1])) {
	die('Specify the name of a job to add. e.g, php queue.php PHP_Job');
}

require __DIR__ . '/init.php';
date_default_timezone_set('GMT');
Resque::setBackend('127.0.0.1:6379');

$names = [
	'李灵黛','冷文卿','阴露萍','柳兰歌','秦水支','李念儿','文彩依','柳婵诗','顾莫言','任水寒','金磨针','丁玲珑','凌霜华','水笙','景茵梦','容柒雁','林墨瞳','华诗','千湄','剑舞','兰陵',' 洛离'
];
foreach($names as $name){
	$jobId = Resque::enqueue('default', 'TestJob', ['name' => $name]);
	echo "Queued job " . $jobId . "\n\n";		
}```

## 写个守护进程脚本
```php
<?php
// demo/resque.php照抄原demo,会发现找不到文件,所以可以照抄我这个
// 这个脚本也是在shell里跑的,真正应用应该放进开机启动里面

date_default_timezone_set('GMT');
require 'bad_job.php';
require 'job.php';
require 'php_error_job.php';

require '/install-path/php-resque/bin/resque';

试一下

先启动守护进程

QUEUE=* php demo/resque.php

会有以下输出

#!/usr/bin/env php
[notice] Starting worker your-computer-name:10757:*

另开一个终端,键入

php demo/queue.php TestJob

会有类似下面输出,那些hash串就是任务id了

Queued job 4b510e225af5897bd5022fee30d202bf

Queued job d14a2ed9339f739b2dec0e0c64069dd7

Queued job d58a536dab2fde9aa6097b37577bd02a

Queued job 53ed1a64d7d8e9a4fed15a0942587e64

Queued job 178ea9087a159c9c7b74b8d9d87e40c2

Queued job cc5dd2087de6865e613fcfdebd52abbc

Queued job e647351c4a83b04b3d701a5dafa52118

Queued job 3f69bd449888e5adb5984a0d64aeb3ac

Queued job 31e114326c8db42443029e14bd677cdb

Queued job 28404f8202a22ade5d204345596d10e0

Queued job fefcf7c402b09c92de2eac5aa642ca80

Queued job e6ecf1529d97e568c5f80bb330c423f2

Queued job c92e64ca49948e7547a5dacce2f373fb

Queued job 97a504c56d74f7714781318b6d244ae6

Queued job 2f8e51937016fc981e0426fcef5d1643

Queued job db3be312811732803fc5d7b814cc69d4

Queued job 23124e4693146812471c09401137a6fd

Queued job af070ce348f73c6c6fe25782351a1937

Queued job 8825fc73b7881e13067e59d10287b598

Queued job 21e31139c9f70c7097927a80a442a577

Queued job 283a8d6119657dd018a5cc8298021bba

这时你看刚才运行守护进程的那个终端,会有类似以下输出,如愿输出了一系列装逼犯

[notice] Starting work on (Job{default} | ID: 3dcf4dc9008d255ab59917a221aaf984 | TestJob | [{"name":"\u674e\u7075\u9edb"}])
李灵黛[notice] (Job{default} | ID: 3dcf4dc9008d255ab59917a221aaf984 | TestJob | [{"name":"\u674e\u7075\u9edb"}]) has finished
[notice] Starting work on (Job{default} | ID: fa2d6bd7a97a77ab754c35822cb8dcd0 | TestJob | [{"name":"\u51b7\u6587\u537f"}])
冷文卿[notice] (Job{default} | ID: fa2d6bd7a97a77ab754c35822cb8dcd0 | TestJob | [{"name":"\u51b7\u6587\u537f"}]) has finished
[notice] Starting work on (Job{default} | ID: 0962a49c4ffd3e987864b2c7e2fdf857 | TestJob | [{"name":"\u9634\u9732\u840d"}])
阴露萍[notice] (Job{default} | ID: 0962a49c4ffd3e987864b2c7e2fdf857 | TestJob | [{"name":"\u9634\u9732\u840d"}]) has finished
[notice] Starting work on (Job{default} | ID: 51ecee3f45d0ba8a906c438ad8ad1887 | TestJob | [{"name":"\u67f3\u5170\u6b4c"}])
柳兰歌[notice] (Job{default} | ID: 51ecee3f45d0ba8a906c438ad8ad1887 | TestJob | [{"name":"\u67f3\u5170\u6b4c"}]) has finished
[notice] Starting work on (Job{default} | ID: 6dbdf11ee30ab874a94d239d93637671 | TestJob | [{"name":"\u79e6\u6c34\u652f"}])
秦水支[notice] (Job{default} | ID: 6dbdf11ee30ab874a94d239d93637671 | TestJob | [{"name":"\u79e6\u6c34\u652f"}]) has finished
[notice] Starting work on (Job{default} | ID: e566a95f0666dcca8fa30c1ed984434f | TestJob | [{"name":"\u674e\u5ff5\u513f"}])
李念儿[notice] (Job{default} | ID: e566a95f0666dcca8fa30c1ed984434f | TestJob | [{"name":"\u674e\u5ff5\u513f"}]) has finished
[notice] Starting work on (Job{default} | ID: 826cfe9d90f06f06f19c790bae54955d | TestJob | [{"name":"\u6587\u5f69\u4f9d"}])
文彩依[notice] (Job{default} | ID: 826cfe9d90f06f06f19c790bae54955d | TestJob | [{"name":"\u6587\u5f69\u4f9d"}]) has finished
[notice] Starting work on (Job{default} | ID: 106843bea773add35576cb796f5a2036 | TestJob | [{"name":"\u67f3\u5a75\u8bd7"}])
柳婵诗[notice] (Job{default} | ID: 106843bea773add35576cb796f5a2036 | TestJob | [{"name":"\u67f3\u5a75\u8bd7"}]) has finished
。。。
。。。
。。。

打完收工

这里是个简单例子,实际上干啥都行,发短信,发邮件,执行不那么着急的数据库操作等等,只管job.php里面写个新class即可,往队列里些消息的时候注意标明一下参数就行

Resque::enqueue('default', 'ClassName', ['参数一' => $param1, '参数二' => $param2,]);

简单应用完全够了

© 著作权归作者所有

inuxor

inuxor

粉丝 33
博文 25
码字总数 14592
作品 0
技术主管
私信 提问
用PHP实现守护进程任务后台运行与多线程(php-resque使用说明)

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

金三胖
2015/08/01
2.1K
1
基于Redis的消息队列php-resque

最近的做一个短信群发的项目,需要用到消息队列。因此开始了我对消息队列选型的漫长路. 为什么选型会纠结呢,直接使用ActiveMQ,RabittMQ,Gearman等流行的消息队列不就可以了吗?在这个项目中,...

mac_zhao
2015/03/10
17.8K
1
利用redis和php-resque实现经典的后台任务

一,由来 在PHP的页面编程过程中,我们总遇到这样一个问题,即是PHP是一个顺序执行的过程,只能在一个任务完成后接着去实现下一个任务,而这其中存在一个问题,就是假如其中一个任务耗费大量...

君满楼001
2017/11/15
0
0
php-resque :基于Redis的后台任务系统

为什么使用php-resque? php-resque 是轻量级后台任务系统,基于Redis,功能设计简单,配置灵活。相比MQ系统大而全的MQ系统,这个显得小而美。 php-resque 角色划分 Job 定义任务,是负责具体...

果树啊
06/23
37
0
PHP 版的 Resque--Php-Resque

Php-Resque 是 Resque 的PHP语言实现版。 使用示例: 1、定义一个任务队列: // Required if redis is located elsewhereResque::setBackend('localhost:6379');$args = array( 'name' => '......

李三石
2014/12/11
2.8K
2

没有更多内容

加载失败,请刷新页面

加载更多

The server time zone value 'EDT' is unrecognized or represents more than one time zone.

2019-10-14 18:07:43.714 ERROR 74363 --- [Druid-ConnectionPool-Create-1855026648] com.alibaba.druid.pool.DruidDataSource : create connection SQLException, url: jdbc:mysql://10.30......

yizhichao
23分钟前
7
0
html加载顺序以及影响页面二次渲染额的因素

本文转载于:专业的前端网站➱html加载顺序以及影响页面二次渲染额的因素 浏览器请求发往服务器以后,返回HTML页面,页面内容开始渲染,具体的执行顺序为: 1. 浏览器开始载入html代码,发现<...

前端老手
25分钟前
7
0
BeginnersBook JSP、JSTL、Servlet 教程

来源:ApacheCN BeginnersBook 翻译项目 译者:飞龙 协议:CC BY-NC-SA 4.0 贡献指南 本项目需要校对,欢迎大家提交 Pull Request。 请您勇敢地去翻译和改进翻译。虽然我们追求卓越,但我们并...

ApacheCN_飞龙
37分钟前
5
0
Handler和内部类的正确用法

PS:本文摘抄自《Android高级进阶》,仅供学习使用   Android代码中涉及线程间通信的地方经常会使用Handler,典型的代码结构如下。 1 2 3 4 5 6 7 8 9 public class HandlerActivity exten...

shzwork
38分钟前
7
0
centos 7 安装mysql5.6rpm格式

centos 7 安装mysql5.6rpm格式 1查看是否安装了mysql rpm -qa|grep -i mysql 如果安装了请卸载:rpm -e --nodeps MySQL... 2、没有安装则进行如下操作 下载mysql rpm tar包 https://dev.mysq...

Archer99
38分钟前
7
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部