当前位置:   article > 正文

Flask使用celery_flask celery

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
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14

tasks.py

@celery.task()
def test():
    with app.app_context():
    	your code
  • 1
  • 2
  • 3
  • 4

虽然在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的,其中就自动应用了上下文。

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/Monodyee/article/detail/414301
推荐阅读
相关标签
  

闽ICP备14008679号