celery的简单介绍
Celery的主要用处是执行异步任务, 可以选择延期或定时执行功能.
- 第一, 假设用户正发起一个request, 并等待request完成后返回. 在这一request后面的view功能中, 我们可能需要执行一段花费很长时间的程序任务, 这一时间可能远远大于 用户能忍受的范围. 当这一任务并不需要立刻执行时,我们便可以使用Celery在后台执 行, 而不影响用户浏览网页. 当有任务需要访问远程服务器完成时, 我们往往都无法确 定需要花费的时间.
- 第二则是定期执行某些任务. 比如每小时需要检查一下天气预报, 然后将数据储存到数据库中. 我们可以编写这一任务, 然后让Celery每天执行一次,统计前一天的数据
安装Celery
我是vietualenv用pip安装的
pip install django-celery
Django设置
如何使用
创建一个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)
原文地址:http://blog.csdn.net/dale_dede/article/details/45697817