django 耗时操作处理办法 celery

来源:互联网 发布:java ee jdk安装教程 编辑:程序博客网 时间:2024/06/07 00:22

django 耗时操作处理办法 celery

1.安装包

celery==3.1.25celery-with-redis==3.0django-celery==3.1.17

2.项目setting.py 配置

# 安装应用INSTALLED_APPS = (  ...  'djcelery',}......#配置代理和任务模块import djcelerydjcelery.setup_loader() #初始化BROKER_URL = 'redis://127.0.0.1:6379/2'  #2为数据库CELERY_IMPORTS = ('test.task')  # '小括号内为应用名.定义耗时方法所在的文件'

3.创建定义耗时操作的方法的文件task.py

from celery import task@taskdef sayhello():    '''    耗时操作的代码    '''     pass

4 .执行迁移生成celery需要的数据库表

在manage.py所在的目录下执行

python manage.py makemigrationspython manage.py migrate

5.启动Redis启动数据库

sodo service redis start

6.启动worker

需要在创建定义完耗时操作方法之后启动

python manage.py celery worker --loglevel=info

7.views中的操作

伪代码

from . import task #导入定义耗时操作方法的文件...def sayhello(request):    task.sayhello.delay()  # 调用耗时操作中的方法,将这个任务加到队列中    return HttpResponse("hello world")