我正在使用 node-celery github 链接与 rabbitmq 一起 实现 celery celery 第一步。
就像在 celery 中一样,我们定义任务然后推送它们。
我在tasks.py中定义的任务如下:
import os
import logging
from celery import Celery
import requests
backend = os.getenv('CELERY_BACKEND_URL', 'amqp')
celery = Celery('tasks', backend=backend)
celery.conf.update(
CELERY_RESULT_SERIALIZER='json',
CELERY_ENABLE_UTC=True
)
@celery.task
def getOrders():
requests.get('locahost:4000/getOrders')
我运行以触发任务的文件:
eta.js:
var celery = require('../celery'),
client = celery.createClient({
CELERY_BROKER_URL: 'amqp://guest:guest@localhost:5672//'
});
client.on('error', function(err) {
console.log(err);
});
client.on('connect', function() {
client.call('tasks.getOrders', {
eta: new Date(Date.now() + 15 * 1000) // an hour later
});
});
我使用以下命令启动 celery worker:
celery worker -A tasks -l info
现在,当我运行 eta.js 并且我在 tasks.py 中定义的任务“getOrders”获得触发器时,它进一步点击了我请求的 url,并且该 URL 完成了它的工作。
要运行 eta.js,我运行:
node eta.js
我想要的是我的任务“getOrders”每 x 秒后继续运行。我已经阅读了有关在 celery周期性任务 celery中设置周期性任务的信息,但它在 python 中,我在 node-celery 中需要它。
如果可能的话,我想在节点芹菜中使用芹菜节拍,还是应该避免使用节点芹菜?并使用 celery python setup,我知道 python,但找不到在 python 中设置 celery 的任何链接。
任何对芹菜有很好了解的人都可以帮助我或指导我学习一些教程。
谢谢!