码迷,mamicode.com
首页 > 其他好文 > 详细

django celery使用

时间:2015-05-13 21:56:04      阅读:212      评论:0      收藏:0      [点我收藏+]

标签:异步   django   后台   

celery的简单介绍

Celery的主要用处是执行异步任务, 可以选择延期或定时执行功能.

  1. 第一, 假设用户正发起一个request, 并等待request完成后返回. 在这一request后面的view功能中, 我们可能需要执行一段花费很长时间的程序任务, 这一时间可能远远大于 用户能忍受的范围. 当这一任务并不需要立刻执行时,我们便可以使用Celery在后台执 行, 而不影响用户浏览网页. 当有任务需要访问远程服务器完成时, 我们往往都无法确 定需要花费的时间.
  2. 第二则是定期执行某些任务. 比如每小时需要检查一下天气预报, 然后将数据储存到数据库中. 我们可以编写这一任务, 然后让Celery每天执行一次,统计前一天的数据

安装Celery

我是vietualenv用pip安装的
pip install django-celery


Django设置

如何使用django-celery完成异步任务


如何使用

  1. 创建一个task
    在django的app中新建一个tasks.py 这个名字你自己可以更改
    正如前面所说的, 一个task就是一个Pyhton function. 但Celery需要知道这一function是task, 因此我们可以使用celery自带的装饰器decorator: @task.
    tasks.py:

    from celery.task import task
    @task(max_retry=3, default_retry_delay=5)
    def task_Tongji_All_Order():
    try:
        #do everything you like
        except Exception, exc:
            raise task_Tongji_All_Order.retry(exc=exc)
  2. 执行task
    这时候我们希望用户在发出request之后,异步执行我们的function

django celery使用

标签:异步   django   后台   

原文地址:http://blog.csdn.net/dale_dede/article/details/45697817

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!