django中使用celery
Posted thotf
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了django中使用celery相关的知识,希望对你有一定的参考价值。
创建django项目celery_demo, 创建应用demo:
django-admin startproject celery_demo
python manage.py startapp demo
#celery.py
from celery import Celery from django.conf import settings import os # 为celery设置环境变量 os.environ.setdefault(‘DJANGO_SETTINGS_MODULE‘, ‘celery_demo.settings‘) # 创建应用 app = Celery("demo") # 配置应用 app.conf.update( # 配置broker, 这里我们用redis作为broker BROKER_URL=‘redis://:[email protected]:6379/1‘, ) # 设置app自动加载任务 # 从已经安装的app中查找任务 app.autodiscover_tasks(settings.INSTALLED_APPS)
在应用demo引用创建tasks.py模块
#taasks.py from celery_demo.celery import app import time # 加上app对象的task装饰器 # 此函数为任务函数 @app.task def my_task(): print("任务开始执行....") time.sleep(5) print("任务执行结束....")
在views.py模块中创建视图index:
from django.shortcuts import render from django.http import HttpResponse from .tasks import my_task def index(request): # 将my_task任务加入到celery队列中 # 如果my_task函数有参数,可通过delay()传递 # 例如 my_task(a, b), my_task.delay(10, 20) my_task.delay() return HttpResponse("<h1>服务器返回响应内容!</h1>")
在celey_demo/settings.py配置视图路由:
from django.conf.urls import url from django.contrib import admin from demo.views import index urlpatterns = [ url(r‘^admin/‘, admin.site.urls), url(r‘^$‘, index), ]
#创建worker celery -A celery_demo worker -l info
#启动django测试 :python manage.py runserver
以上是关于django中使用celery的主要内容,如果未能解决你的问题,请参考以下文章
Celery Django 未注册任务,shell 中未找到模块错误
由于 ImportError,Celery Django 部署因 Elastic Beanstalk 失败:无法导入名称“Celery”(ElasticBeanstalk::ExternalInvoc