码迷,mamicode.com
首页 > 其他好文 > 详细

Django 异步化库celery

时间:2019-03-19 12:31:32      阅读:142      评论:0      收藏:0      [点我收藏+]

标签:bind   view   def   sel   怎么   over   图片   settings   ports   

首先要了解Django其实是个同步框架,那么多个用户发送请求时就会发生排队的情况上一个用户的请求完成后在进行下一个,这样会对影响用户体验,所有就要用到异步方法来解决。

首先我们要安装celery库

pip install celery   celery的基础库

pip install celery-with-redis  celery对redis的库

pip install django-celery  celery对django的库

 

安装完成后要在settings.py内进行设置

#配置celery
import djcelery
djcelery.setup_loader()
BROKER_URL = redis://127.0.0.1:6379
CELERY_IMPORTS = (mymac.tasks)

 

 

还要在同级目录下建立一个 celert.py文件

#导包
import os
import django
from celery import Celery
from django.conf import settings 
os.environ.setdefault(DJANGO_SETTINGS_MODULE, mymac.settings)
django.setup()
app = Celery(mymac)
app.config_from_object(django.conf:settings)
app.autodiscover_tasks(lambda: settings.INSTALLED_APPS)
@app.task(bind=True)
def debug_task(self):
    print(Request: {0!r}.format(self.request))

 

 

然后建立一个py文件 创建celert异步方法

#导包
import time
#导入异步任务
from celery.task import task

#task使用装饰器用法
@task
def say(x,y):
    #稍后用于方便查看异步
    time.sleep(5)
    return x+y

 

 

 

在视图方法导入写好的异步方法,配置好相应路由访问即可

from django.shortcuts import render,redirect
#导包
from django.http import HttpResponse,HttpResponseRedirect
#导入类视图 
from django.views import View
#导入异步方法
from mymac.tasks import sayl

def celery_test(request):
    #用delay传参
    print(say.delay(123,123))
    return HttpResponse(异步测试)

 

 

那怎么看是否是异步呢

我们需要在启动一个监听异步的服务,需要进入你的项目文件来启动服务命令是  celery -A mymac worker -l info   mymac为项目名

技术图片

然后我们去发送请求,连续刷新相应请求页面已达到模拟多个用户同时访问

这个时候我们可以看到多个请求在发送但是我们在方法里设置了延时5秒所有只发送并没有完成

技术图片

 

5秒后我们看到都开始相继完成了

技术图片

 

Django 异步化库celery

标签:bind   view   def   sel   怎么   over   图片   settings   ports   

原文地址:https://www.cnblogs.com/Niuxingyu/p/10557594.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!