首页 > 编程 > Python > 正文

django之使用celery-把耗时程序放到celery里面执行的方法

2019-11-25 12:23:44
字体:
来源:转载
供稿:网友

1 在虚拟环境创建项目test和应用booktest(过程省略),然后安装所需的包

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

2 配置settings,

# 数据库使用mysqlDATABASES = {  'default': {    'ENGINE':'django.db.backends.mysql',    'NAME':'test',    'USER':'root',    'PASSWORD':'mysql',    'HOST':'localhost',    'PORT':3306,  }}# 注册djcelery应用INSTALLED_APPS = (  ...  'djcelery',)# celery配置# 如报错 ImportError: No module named djcelery ,是因为没有在虚拟环境运行导致, workon h1进入虚拟环境再运行解决import djcelery# 初始化所有的task任务,这些任务来自booktest.task模块djcelery.setup_loader()# 使用redis第0个数据库,并绑定ip端口BROKER_URL='redis://127.0.0.1:6379/0'# 设置初始化的任务来源CELERY_IMPORTS = 'booktest.task'

3 在应用目录booktest下面创建任务列表文件task.py

from celery import taskimport time# 加上@task装饰器,则python函数就变成一个celery任务@taskdef celery_test():  print('hello...')  time.sleep(5)  print('world...')

4 创建视图,并配置相关的url配置,把耗时任务放入视图被调用

# -*- coding:utf-8 -*-from django.shortcuts import renderfrom django.http import HttpResponsefrom task import celery_test# celery练习1:把耗时程序放在celery中执行def celerytest(request):  # function.delay(参数),celery任务celery_test调用方法  celery_test.delay()  return HttpResponse('ok')# 根级url配置 test.urlsfrom django.conf.urls import include, urlfrom django.contrib import adminurlpatterns = [  url(r'^admin/', include(admin.site.urls)),  url(r'^celery/', include('booktest.urls')),]# 应用下的url配置 booktest.urlsfrom django.conf.urls import urlimport viewsurlpatterns=[  url(r'^celerytest/$', views.celerytest)]

5 迁移,生成celery所需的数据表

python manage.py migrate

6 启动redis

sudo redis-server /etc/redis/redis.conf

7 启动worker

python manage.py celery worker --loglevel=info

8 另开一个终端窗口,启动django服务器

python manage.py runserver

9 测试,输入url,如 http://127.0.0.1:8000/celery/celerytest/,则返回'ok'

同时,会在worker对应的窗口看到耗时任务程序在此输出,即当用户请求时,不用等待太久就可以得到结果'ok',同时耗时任务程序也被异步执行,提高用户体验.

以上这篇django之使用celery-把耗时程序放到celery里面执行的方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持武林网。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表