sql >> Base de Datos >  >> NoSQL >> Redis

Django:cómo usar la cola de tareas asincrónicas con apio y redis

Como se dijo anteriormente, es posible que no necesite apio. Aquí hay un ejemplo derivado del caso 2 de esto:https://zapier.com/blog/async-celery-example-why-and-how/. Está funcionando completamente para mí:

from time import sleep
import json
from django.http import HttpResponse
from django.shortcuts import render

def main_view(request):
    return render(request, 'index.html')

def ajax_view(request):
    sleep(10) #This is whatever work you need
    pi1 = "This is pi1" #I just made pi1/pis1 random values
    pis1 = "This is pis1"
    context = {
        "pi1" : pi1,
        "pis1" : pis1,
    }
    data = json.dumps(context)

    return HttpResponse(data, content_type='application/json')

Mi index.html contiene:

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="utf-8">
    <title>Main View</title>
    <script src="//code.jquery.com/jquery-1.11.3.min.js"></script>
    <script>
    $(document).ready(function(){
        $.ajax({
            url: "/test_ajax/",
        }).done(function( data) {
            $("#pi1").text(data.pi1);
            $("#pis1").text(data.pis1); 
        });
    });
</script>
  </head>
  <body>
      <h1 id = "pi1">Loading</h1>
      <h1 id = "pis1">Loading</h1>
  </body>
</html>

Y mi urls.py contiene:

from django.conf.urls import include, url
from django.contrib import admin
from testDjango.test import main_view, ajax_view

urlpatterns = [
    url(r'^admin/', include(admin.site.urls)),
    url(r'^test/', main_view),
    url(r'^test_ajax/', ajax_view)
]

Lo que sucede cuando visito localhost:8000/test/ es que instantáneamente ver:

Después de unos 10 segundos, veo:

La idea es que regrese su página instantáneamente y use jquery para obtener el resultado de la operación cuando termine y actualice su página en consecuencia. Puede agregar más cosas como barras de progreso/cargar imagen, etc. Para su ejemplo, puede hacer el procesamiento para pi1 y pis en segundo plano y cárguelo en el HTML una vez que haya terminado.