django celery使用

celery的简单介绍

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

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

安装Celery

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


Django设置

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

python manage.py celery worker --loglevel=info

如何使用

  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
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值