经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 程序设计 » Django » 查看文章
使用celery执行Django串行异步任务的方法步骤
来源:jb51  时间:2019/6/6 9:47:24  对本文有异议

前言

Django项目有一个耗时较长的update过程,希望在接到请求运行update过程的时候,Django应用仍能正常处理其他的请求,并且update过程要求不能并行,也不能漏掉任何一个请求

使用celery的solo模式解决

安装redis

https://github.com/microsoftarchive/redis/releases

下载.msi文件安装,会直接将redis注册为windows服务

安装celery与redis依赖

  1. pip install celery
  2. pip indatll redis

一个celery应用

  1. # celery_test.py
  2. import time
  3.  
  4. from celery import Celery
  5.  
  6. app = Celery('tasks', broker='redis://127.0.0.1:6379/0')
  7.  
  8.  
  9. @app.task
  10. def add(x, y):
  11. time.sleep(5)
  12. return x + y
  13.  

启动celery服务

  1. celery -A celery_test.app worker --pool=solo -l info

查看完整的命令行参数列表

  1. celery worker --help

对celery启动命令的解释

  • '-A' 是一个全局配置,定义了APP的位置
  • '--pool' 是POOL的配置,默认是prefork(并发),选择solo之后,发送的任务不会被并发执行,在worker执行任务过程中,再次发送给worker的任务会排队,执行完一个再执行另一个
  • '-l' 是WORKER的配置,定义了log级别

调用任务

  1. >>> from celery_test import add
  2. >>> add.delay(4,4)

因为启动了solo模式,因此,可以看到在一个add没有执行完前,即使再次发送执行add的任务,celery worker也会等到前一个任务执行完才去执行下一个

与Django结合

在装载celery应用前先setup django

  1. import time
  2. import os
  3. import django
  4. os.environ.setdefault("DJANGO_SETTINGS_MODULE", "demo.settings")
  5. django.setup()
  6.  
  7. from celery import Celery
  8.  
  9. from django_app.update import update
  10.  
  11. app = Celery('tasks', broker='redis://127.0.0.1:6379/0', backend='redis://127.0.0.1:6379/0')
  12.  
  13. @app.task
  14. def update_task():
  15. update()
  16.  

然后在views中调用task就可以了。

  1. from celery_test import update_task
  2. def update_api(request):
  3. if request.method == "GET":
  4. update_task.delay()
  5. return HttpResponse(status=status.HTTP_200_OK)

执行过程中,程序的print信息会作为celery warning,报错信息会作为celery error

日志

在启动应用的时候指定日志文件路径

  1. -f log_path

不设置这个参数的时候,日志默认输出到控制台

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持w3xue。

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号