php-resque 极简php消息队列-程序员宅基地

技术标签: git  shell  php  

安装

  • 首先这货需要在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,]);

简单应用完全够了

转载于:https://my.oschina.net/inuxor/blog/635959

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/chikengjue5325/article/details/100931714

智能推荐

机器学习【1】决策树中ID3、C4.5、C5.0、CART、CHAID、QUEST算法_c5.0 chaid-程序员宅基地

文章浏览阅读1.9k次。C4.5和C5.0的区别:C5.0是C4.5应用于大数据集上的分类算法,主要在执行效率和内存使用方面进行了改进。CHAID算法根节点的选取:每个输入变量和输出变量(标签)做独立性检验,卡方值最大(P值最小)的为父节点,也就是说,跟输出变量相关的显著性最高的变量作为根节点。节点的分裂:一、连续型输入变量:1、先将输入变量进行区间划分,比如输入变量为价格,价格的最小单位是1元,那么,组距为1,划分区间为[1]、[2]、[3]、…,计算每个区间里面的频数,再算出与输出变量的交叉表。._c5.0 chaid

Docker 部署 jenkins 并正确迁移到新服务器-程序员宅基地

文章浏览阅读832次。docker 部署的 jenkins 并正确迁移到新服务器

java中interface的使用以及注意事项_interface在java中的用法-程序员宅基地

文章浏览阅读4.2k次。java中interface的使用以及注意事项_interface在java中的用法

小波变换边缘提取程序_基于小波变换的轮廓提取工具-程序员宅基地

文章浏览阅读1.4k次。1.小波变换边缘提取程序clear all; load wbarb; %小波变换边缘提取程序I = ind2gray(X,map);%检索图转成灰度图imshow(I); I1 = imadjust(I,stretchlim(I),[0,1]);%调整图像的像素值,可以改变对比度和颜色figure;imshow(I1); [N,M] = size(I); h = [0.125,0..._基于小波变换的轮廓提取工具

Spring源码分析(八)Bean的实例化(上)_docreatebean时克隆beandefinition-程序员宅基地

文章浏览阅读4.5k次。上一节我们看到正对不同作用域Bean的加载,但是Bean的核心创建我们还没有说,下面我们来看看Bean的核心加载也就是CreateBean与DoCreateBean方法的核心实现AbstractAutowireCapableBeanFactory根据设置的class属性或者根据className来解析Class,这里面逻辑十分复杂,但是我们可以猜想他的作用,不就是通过类加载来实例化我们编写,并组装成RootBeanDefinition,前面我们也说过所有的Bean后续处理都是针对于RootBeanDef_docreatebean时克隆beandefinition

飞行管理数学建模论文_飞机的安全飞行管理调度问题1995年csdn-程序员宅基地

文章浏览阅读6.7k次,点赞13次,收藏95次。飞行管理问题建模目录(1)摘要(2)问题重述(3)问题分析(4)模型假设(5)符号说明(6)模型的建立与求解(7) 模型的缺点与改进方向摘要对飞行区域内的飞机,通过调整飞机飞行的角度且飞机调整的幅度要尽量小来避免飞机相撞的的问题,本文先将区域内任意两架飞机在区域内飞行时不相撞的条件转化成关于飞机在飞行区域内关于飞行时间的非线性约束条件,即任意两架飞机在未飞出区域的时间里,..._飞机的安全飞行管理调度问题1995年csdn

随便推点

发现了以元素'd:skin'开头的无效内容,此处不应含有元素——Eclipse下配置Android时的错误警告处理_tag e:skin has duplicated attribute xmlns:xdw-程序员宅基地

文章浏览阅读726次。在Eclipse环境下配置Android开发环境,安装完SDK和ADT之后,打开Eclipse时候,出现如下错误警告。 针对此问题,其解决方法如下: (1)删除上图中显示的2处路径下的devices.xml文件 (2)将安装SDK的路径(android-sdk)下的tools\lib路径下的devices.xml复制到上述步骤中的2处路径处,替换原有的devices.x_tag e:skin has duplicated attribute xmlns:xdw

SpringCloud+Vue在线教育网站——整合Gateway网关_getway-程序员宅基地

文章浏览阅读6.8k次,点赞2次,收藏9次。API 网关出现的原因是微服务架构的出现,不同的微服务一般会有不同的网络地址,而外部客户端可能需要调用多个服务的接口才能完成一个业务需求,如果让客户端直接与各个微服务通信,会有以下的问题:_getway

sparkshelljarlib_Spark jar包问题-程序员宅基地

文章浏览阅读335次。通常我们将spark任务编写后打包成jar包,使用spark-submit进行提交,因为spark是分布式任务,如果运行机器上没有对应的依赖jar文件就会报ClassNotFound的错误。下面有二个解决方法:根据spark官网,在提交任务的时候指定–jars,用逗号分开。这样做的缺点是每次都要指定jar包,如果jar包少的话可以这么做,但是如果多的话会很麻烦。spark-submit --mas..._spark-shell 指定jar包

在Windows下编译mongo-c-driver 1.3.x-程序员宅基地

文章浏览阅读137次。在Windows下编译mongo-c-driver 1.3.x在Windows下编译mongo-c-driver 1.3.x1.安装 MSYS2https://sourceforge.net/projects/msys2/2.如果是32位系统或编译32位程序,运行 mingw32_shell.bat 64位运行 mingw64_shell.bat2.1编译64位,安装 MinGW..._mongo-c-driver bianyi zlib

windows SDK之间的关联_windows sdk 向下兼容-程序员宅基地

文章浏览阅读431次。转载:SDK,DLL,API,MFC 的关系与理解_大拿的博客-程序员宅基地win10 sdk 是否向下兼容_lindexi_gd的博客-程序员宅基地SDK是Software Development Kit的缩写,中文意思是“软件开发工具包”。这是一个覆盖面相当广泛的名词,可以这么说:辅助开发某一类软件的相关文档、范例和工具的集合都可以叫做“SDK”。具体到我们这个系列教程,我们后面只讨论广义 SDK 的一个子集——即开发 Windows 平台下的应用程序所使用的 SDK。当项目一个项目中有_windows sdk 向下兼容

一零二、Vue中自定义emoji表情包_vue自定义选择emoji表情-程序员宅基地

文章浏览阅读5.1k次。最近有需求要在后台管理支持自定义的emoji输入,记录一下开发过程。1. 表情包命名2. 定义表情包符合3. 编写emoji组件4. 页面中使用5. emoji展示1. 表情包命名表情包数量太多,命名到手抖 推荐使用神器 Everything 2. 定义表情包符合多端使用的话需要统一表情包的符号{ "xdx_001": "[-|xdx_001|-]" ..._vue自定义选择emoji表情