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 页面