我可以每隔一秒钟使用一次芹菜吗?

时间:2016-11-28 14:40:58

标签: celery

我每秒都在运行任务,似乎芹菜实际上并没有执行任务。

我猜芹菜可能是每1分钟任务的好调度程序,但可能不适合每一项任务。

这张照片将说明我的意思

enter image description here

我正在使用以下选项

     'schedule': 1.0,
     'args': [],
     'options': {
         'expires': 3
     }

我正在使用芹菜4.0.0

1 个答案:

答案 0 :(得分:0)

是的,Celery实际上处理时间低至1秒,并且可能更低,因为它需要浮动。请参阅文档http://docs.celeryproject.org/en/latest/userguide/periodic-tasks.html中的定期任务条目:

from celery import Celery
from celery.schedules import crontab

app = Celery()

@app.on_after_configure.connect
def setup_periodic_tasks(sender, **kwargs):
    # Calls test('hello') every 10 seconds.
    sender.add_periodic_task(10.0, test.s('hello'), name='add every 10')

    # Calls test('world') every 30 seconds
    sender.add_periodic_task(30.0, test.s('world'), expires=10)

    # Executes every Monday morning at 7:30 a.m.
    sender.add_periodic_task(
        crontab(hour=7, minute=30, day_of_week=1),
        test.s('Happy Mondays!'),
    )

@app.task
def test(arg):
    print(arg)

更好的书面例子可以在https://github.com/celery/celery/issues/3589下方的1/3处找到:

# file: tasks.py
from celery import Celery

celery = Celery('tasks', broker='pyamqp://guest@localhost//')

@celery.task
def add(x, y):
    return x + y


@celery.on_after_configure.connect
def add_periodic(**kwargs):
    celery.add_periodic_task(10.0, add.s(2,3), name='add every 10')

所以sender是实际的Celery经纪人,即app = Celery()