关于 python:如何在 PHP 中的 celery-rabbitmq 队列上发布任务?

How to post a task on a celery-rabbitmq queue in PHP?

我安装了以下版本的 celery 和 rabbitmq -

celery 3.1.6
rabbitmq 3.1.1

我可以将任务从 PHP 发布到默认队列 -

1
2
3
4
5
//client.php
<?php
require 'celery-php/celery.php';
$c = new Celery('localhost', 'guest', 'guest', '/');
$result = $c->PostTask('tasks.add', array(2,2));

我的工作模块在 python 中 -

1
2
3
4
5
6
# tasks.py
from celery import Celery
celery = Celery('tasks', broker='amqp://guest:guest@localhost:5672//')
@celery.task(queue='demo', name='add')
def add(x, y):
    return x + y

我像这样运行芹菜工人和客户端 -

1
2
3
4
# terminal window 1
$ celery -A tasks worker --loglevel=info
# terminal window 2
$ php -f client.php

这有效。我在终端窗口 1 中看到以下输出:

1
2
Received task: tasks.add[php_52b1759141a8b3.43107845]
Task tasks.add[php_52b1759141a8b3.43107845] succeeded in 0.000701383920386s: 4

但我想要不同的队列。为了演示,假设我只想要一个名为 demo 的队列。所以我像这样运行我的芹菜工人 -

1
$ celery -A tasks worker --loglevel=info -Q demo

但它不起作用。任务没有被执行。我想这可能是因为 PHP 代码在默认队列上发布了任务:celery(显然不在演示队列上)。

如何在 PHP 中将我的任务发布到特定队列中?请帮忙。


默认情况下,Celery 的 PHP 客户端将队列名称设为 "celery"。

为了更改要发布到的队列,您必须在实例化与 Celery 的连接时指定队列名称。
因此,如果您使用 "-Q demo" 选项启动 Celery worker,那么您在 PHP 中与 Celery 的连接应该是 -

1
2
3
$exchange = 'demo';
$binding = 'demo';
$c = new Celery('localhost', 'guest', 'guest', '/', $exchange, $binding);

注意:使用 -Q 选项,exchange 和 routing_key 值与 queue_name 相同。

请试试这个并分享结果。

关于交换和绑定:

与电话服务类比,Exchange 就像"电话接线员",其唯一的工作是在routing_key 的帮助下"将呼叫转接到您"。

然后绑定是"您的电话号码",它充当您电话的routing_key。

注意:这个交换基于绑定(routing_key)将传入消息重定向到队列的过程是一种直接交换类型。
AMQP 几乎没有其他类型的交换,您可以在 AMQP 文档中阅读。

你也可以参考这个 Celery 页面