Redis
 sql >> Base de données >  >> NoSQL >> Redis

Django - Comment utiliser la file d'attente de tâches asynchrone avec le céleri et redis

Comme dit précédemment, vous n'aurez peut-être pas besoin de céleri. Voici un exemple dérivé du cas 2 :https://zapier.com/blog/async-celery-example-why-and-how/. Cela fonctionne parfaitement pour moi :

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

Mon index.html contient :

<!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>

Et mon urls.py contient :

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

Ce qui se passe lorsque je visite localhost:8000/test/, c'est que je instantanément voir :

Après environ 10 secondes, je vois alors :

L'idée est que vous renvoyiez votre page instantanément et que vous utilisiez jquery pour récupérer le résultat de l'opération chaque fois que celle-ci est terminée et que vous mettiez à jour votre page en conséquence. Vous pouvez ajouter plus de choses comme des barres de progression/chargement d'image etc. Pour votre exemple, vous pouvez faire le traitement pour pi1 et pis en arrière-plan et chargez-le dans le HTML une fois terminé.