Redis
 sql >> Base de Dados >  >> NoSQL >> Redis

Django - Como usar a fila de tarefas assíncronas com aipo e redis


Como foi dito anteriormente, você pode não precisar de aipo. Aqui está um exemplo derivado do caso 2 deste:https://zapier.com/blog/async-celery-example-why-and-how/. Está totalmente funcionando para mim:
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')

Meu index.html contém:
<!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 meu urls.py contém:
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)
]

O que acontece quando eu visito localhost:8000/test/ é que eu instantaneamente Vejo:



Após cerca de 10 segundos, vejo:



A ideia é que você retorne sua página instantaneamente e use jquery para buscar o resultado da operação sempre que terminar e atualize sua página de acordo. Você pode adicionar mais coisas como barras de progresso/carregar imagem etc. Para seu exemplo, você pode fazer o processamento para pi1 e pis em segundo plano e carregá-lo no HTML depois que terminar.