Redis
 sql >> Database >  >> NoSQL >> Redis

Django - Come utilizzare la coda di attività asincrona con sedano e redis

Come detto in precedenza, potrebbe non essere necessario il sedano. Ecco un esempio derivato dal caso 2 di questo:https://zapier.com/blog/async-celery-example-why-and-how/. Per me funziona perfettamente:

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')

Il mio 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>

E il mio 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)
]

Quello che succede quando visito localhost:8000/test/ è che io istantaneamente vedi:

Dopo circa 10 secondi, vedo:

L'idea è che tu restituisca immediatamente la tua pagina e usi jquery per recuperare il risultato dell'operazione ogni volta che è finita e aggiornare la tua pagina di conseguenza. Puoi aggiungere più cose come barre di avanzamento/caricamento dell'immagine ecc. Per il tuo esempio, puoi eseguire l'elaborazione per pi1 e pis in background e caricarlo nell'HTML al termine.