Flask+Celery+Redis简单操作

本文介绍了如何使用Flask、Celery和Redis实现异步任务处理。通过创建Celery实例,配置broker和backend为Redis,将任务放入tasks.py,并在Flask视图中调用。尽管在Windows上可能会遇到兼容性问题,但通过安装额外的包并在启动Celery时指定,可以成功运行并展示运行成功的效果。
摘要由CSDN通过智能技术生成

使用celery可以使得任务异步执行,在处理复杂或耗时长的任务时经常需要,废话不多说,直接进入正题。

结构树
在这里插入图片描述
安装各种包

pip install celery
pip install radis

_init_.py文件中添加celery实例的创建函数

def make_celery(app=None):
    app = app or create_app('default')
    # 异步队列
    celery = Celery(app.name, broker=CELERY_BROKER_URL, backend=CELERY_RESULT_BACKEND)
    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

同时导入app.config的文件中(或者直接设置)添加broker和backend,在这里我用的都是redis

    CELERY_BROKER_URL = 'r
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值