Celery异步任务

匿名 (未验证) 提交于 2019-12-03 00:39:02

  在实际开发过程中,会遇到很多耗时操作,这时如果不采取措施,程序会进入到阻塞状态,直到耗时任务完成,为了保证整个项目的流畅性,通常会对这些耗时任务进行异步操作,具体步骤如下:

  1.创建celery_tasks用于保存celery异步任务

  2.在celery_tasks目录下创建config.py文件,用于保存celery的配置信息

    broker_url = "redis://127.0.0.1/14"

  3.在celery_tasks目录下创建main.py文件,用于作为celery的启动文件

    

from celery import Celery  # 为celery使用django配置文件进行设置 import os if not os.getenv(DJANGO_SETTINGS_MODULE):     os.environ[DJANGO_SETTINGS_MODULE] = xxx.settings.dev  # 创建celery应用 app = Celery(xxx)  # 导入celery配置 app.config_from_object(celery_tasks.config)  # 自动注册celery任务 app.autodiscover_tasks([celery_tasks.xxx])

  4.在celery_tasks目录下创建xxx任务目录,用于放置部署任务的异步任务相关代码。

  5.在celery_tasks/xxx/目录下创建tasks.py文件,用于保存部署任务的异步任务

  6.用装饰器装饰异步任务:

@app.task(name=起别名)

  7.在需要执行异步任务的地方导入异步任务,并使用 异步任务名.delay()执行

原文:https://www.cnblogs.com/zc2018/p/9266024.html

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!