Flask使用celery

项目结构图

pip install celery
pip install redis
在这里插入图片描述

celery_worker.py

  • 当celery用到flask上下文时,需要用以下定义的方式,并且传入flask的实例对象
from celery import Celery


def make_celery(app):
    celery = Celery(app.import_name, broker="redis://localhost:6379/0")
    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

tasks.py

@celery.task()
def test():
    with app.app_context():
    	your code

虽然在celery应用flask实例对象,但是如果代码里面应用到了例如flask_sqlalchemy,它也需要用到上下文。
应该注意的是,避免造成循环导包,app实例来自main.py 即from main import app

启动

celery -A app.task.tasks:celery worker --loglevel=info
如果不加loglevel,控制台是反馈信息的

Flask-Celery-Helper 是一个flask三方库,也是配置celery的,其中就自动应用了上下文。

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值