Flask 芹菜用烧瓶敲打任务问题

Flask 芹菜用烧瓶敲打任务问题,flask,celery,celerybeat,Flask,Celery,Celerybeat,我想用芹菜在烧瓶上做cron作业,但我对芹菜节拍计划有一个问题,因为我的任务似乎没有加载,我不知道如何检查问题出在哪里 这是我在views.py中定义Flask应用程序的地方: from celery.schedules import crontab app = Flask(__name__) app.config.update( CELERY_BROKER_URL='redis://localhost:6379', CELERY_RESULT_BACKEND='redis:/

我想用芹菜在烧瓶上做cron作业,但我对芹菜节拍计划有一个问题,因为我的任务似乎没有加载,我不知道如何检查问题出在哪里

这是我在views.py中定义Flask应用程序的地方:

from celery.schedules import crontab

app = Flask(__name__)
app.config.update(
    CELERY_BROKER_URL='redis://localhost:6379',
    CELERY_RESULT_BACKEND='redis://localhost:6379',
    CELERY_BEAT_SCHEDULE={
        'task-number-one': {
            'task': 'app.tasks.test',
            'schedule': crontab(minute="*"),
        }
    },
    CELERY_IMPORTS = ('app.tasks'),
    CELERY_TASK_RESULT_EXPIRES = 30,
    CELERY_TIMEZONE = 'UTC',
)
这是在tasks.py中创建芹菜对象的地方:

from celery import Celery
from app.views import app
from celery import shared_task


def make_celery(app):
    celery = Celery(app.import_name, backend=app.config['CELERY_RESULT_BACKEND'],
                    broker=app.config['CELERY_BROKER_URL'])
    celery.conf.update(app.config)
    TaskBase = celery.Task
    class ContextTask(TaskBase):
        abstract = True
        def __call__(self, *args, **kwargs):
            with app.app_context():
                return TaskBase.__call__(self, *args, **kwargs)
    celery.Task = ContextTask
    return celery

celery_app = make_celery(app)

@celery_app.task()
def test():
    logger = test.get_logger()
    logger.info("Hello")
views.py和tasks.py位于同一目录下,称为app

这是我在启动芹菜工人(这里一切似乎都很正常)时所做的:

但这就是我在启动芹菜节拍时所拥有的,似乎我的任务从未按我的日程安排发送,但我不知道去哪里查看:

你能帮我吗?
Best

我认为芹菜节拍任务至少需要在发送了
@app.on\u configure.connect
信号之后进行配置。您应该能够在tasks.py文件中执行以下操作

celery_app.conf.CELERYBEAT_SCHEDULE = {
    "test-every-minue": {
    "task": "tasks.test",
    "schedule": crontab(minute="*"),
     },
}
或者,如果任务与芹菜应用程序实例定义在同一文件中,则可以使用此装饰器语法

@celery_app.on_after_configure.connect
def setup_periodic_tasks(sender, **kwargs):
    sender.add_periodic_task(5 , test_two.s(), name='test-every-5')
如果您的任务是在单独的模块中定义的,您可以在完成后使用
@app.on\u。导入任务后连接
装饰程序

@app.on_after_finalize.connect
def setup_periodic_tasks(sender, **kwargs):
    from app.tasks import test
    sender.add_periodic_task(10.0, test.s(), name='test-every-10')