Используйте Channel API для получения сообщений от задачи в очереди задач

Я пытаюсь понять API очереди задач и канала.

У меня есть процесс, который, как ожидается, будет запущен> 60 секунд, добавленный в очередь задач, когда пользователь отправляет форму. Затем этот процесс должен отправлять сообщения через канал API по мере его выполнения. Грубо говоря, я не могу заставить эту работу работать. Может ли кто-нибудь сказать мне, почему SendMessagesHandler не может отправлять сообщения на javascript на стороне клиента? Или, возможно, javascript на стороне клиента не принимает должным образом? Кроме того, я не вижу сообщения logging от SendMessagesHandler в консоли журнала, она показывает только работу мельницы INFO ... GET или POST. Когда я пишу это, я понимаю, что у меня должно быть более одной проблемы, задача создается в очереди задач, я вижу ее в консоли SDK, однако, похоже, она просто продолжает работать бесконечно, я ожидал он должен работать примерно 1 м 2 сек. Если я возьму команды sleep из SendMessageHandler, они запустятся слишком быстро, чтобы поймать их даже в консоли SDK.

Заранее спасибо за помощь.

Вот файл main.py:

#!/usr/bin/env python
import webapp2
import os
import jinja2
import logging
from time import sleep
from google.appengine.api import taskqueue, users, channel
from google.appengine.ext import db

class MainHandler(webapp2.RequestHandler):
    def get(self):
        user = users.get_current_user()
        if user:
            key = self.request.get('key')
            if not key:
                key = user.user_id()
            key_link = 'http://localhost:8080/?key=' + key
            token = channel.create_channel(key)
            template_values = {'token': token,
                    'me': user.user_id(),
                    'key': key,
                    'key_link': key_link,
                    'initial_message': 'Nothing to show yet'}
            template = jinja_environment.get_template('template.html')
            self.response.out.write(template.render(template_values))
        else:
            self.redirect(users.create_login_url(self.request.uri))

    def post(self):
        key = self.request.get('key')
        taskqueue.add(url='/sendmessages', params={'key': key})
        self.redirect('/')

class SendMessagesHandler(webapp2.RequestHandler):
    def post(self):
        key = self.request.get('key')
        sleep(2)
        channel.send_message(key, 'Starting to send messages...')
        logging.info('Starting to send messages...')
        i = 0
        while i < 60:
            i += 1
            logging.info('Counter incremented.')
            channel.send_message(key, 'Counter incemented.')
            sleep(1)

jinja_environment = jinja2.Environment(
        loader=jinja2.FileSystemLoader(os.path.dirname(__file__)))
app = webapp2.WSGIApplication([
        ('/', MainHandler),
        ('/sendmessages', SendMessagesHandler)
    ], debug=True)

а вот и шаблон.html

<html>
    <head>
        <title>Simple Task Queue Channel API</title>
        <script src='/_ah/channel/jsapi'></script>
    </head>
    <body>
        <script type='text/jacascript'>
            onOpened = function() {};
            onMessage = function(message) {
                var messageBox = document.getElementById("messageBox");
                messageBox.innerHTML = message;
            };
            onError = function() {};
            onClose = function() {};
            channel = new goog.appengine.Channel('{{token}}');
            socket = channel.open();
            socket.onopen = onOpened;
            socket.onmessage = onMessage;
            socket.onerror = onError;
            socket.onclose = onClose;
        </script>
        <form method="post" action="/">
            <input type="text" name="key" value="{{ key }}">
            <input type="submit" name="submit" value="Receive Messages">
        </form>
        <div id="messageBox"><!-- message should go in here --></div>
    </body>
</html>

Вот источник просмотра из браузера:

<html>
<head>
    <title>Simple Task Queue Channel API</title>
    <script src='/_ah/channel/jsapi'></script>
</head>
<body>
    <script type='text/jacascript'>
        onOpened = function() {};
        onMessage = function(message) {
            var messageBox = document.getElementById("messageBox");
            messageBox.innerHTML = message;
        };
        onError = function() {};
        onClose = function() {};
        channel = new goog.appengine.Channel('channel-2840733866-1367208241-185804764220139124118');
        socket = channel.open();
        socket.onopen = onOpened;
        socket.onmessage = onMessage;
        socket.onerror = onError;
        socket.onclose = onClose;
    </script>
    <form method="post" action="/">
        <input type="text" name="key" value="185804764220139124118">
        <input type="submit" name="submit" value="Receive Messages">
    </form>
    <div id="messageBox"><!-- message should go in here --></div>
</body>
</html>

person David Dickson    schedule 29.04.2013    source источник


Ответы (1)


Я вижу как минимум две ошибки:

Первый

<script type='text/javascript'>

Второй

onMessage = function(message) {
        var messageBox = document.getElementById("messageBox");
        messageBox.innerHTML = message.data;
    };
person dragonx    schedule 29.04.2013
comment
Вау, я должен был немного поспать, прежде чем опубликовать это. Спасибо, dragonx, это все, что нужно! Я разместил это на github для всех, у кого могут возникнуть трудности с запуском и запуском Channel-API: github.com/forestcoder/simple-task-queue-channel-api - person David Dickson; 30.04.2013