当前位置: 代码迷 >> 综合 >> django 耗时操作处理办法 celery
  详细解决方案

django 耗时操作处理办法 celery

热度:92   发布时间:2023-12-12 09:31:33.0

django 耗时操作处理办法 celery

1.安装包

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

2.项目setting.py 配置

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

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

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

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

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

python manage.py makemigrations
python 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")