Spójrz na Server-Sent Events. Zdarzenia wysyłane z serwera to interfejs API przeglądarki, który umożliwia otwieranie gniazda na serwerze, subskrybowanie strumienia aktualizacji o . Aby uzyskać więcej informacji, przeczytaj artykuł Alexa MacCawa (autor Juggernaut) na why he kills juggernaut i dlaczego łatwiejsze Zdarzenia wysłane z serwera są w zwykłych przypadkach lepszym narzędziem do pracy niż te, które są dostępne w sieci Web: .
Protokół jest naprawdę łatwy. Po prostu dodaj typ MIME text/event-stream
do odpowiedzi . Przeglądarka pozostawi otwarte połączenie i będzie nasłuchiwać aktualizacji. Zdarzenie wysłane z serwera jest wierszem tekstu rozpoczynającym się od data:
i następującym znakiem nowej linii.
data: this is a simple message
<blank line>
Jeśli chcesz wymieniać dane strukturalne, po prostu zrzucić swoje dane jako json i wysłać JSON nad drutu.
Zaletą jest to, że można użyć SSE w kolbie bez potrzeby dodatkowego serwera . Jest prosty chat application example na github, który wykorzystuje redis jako backend pub/sub.
def event_stream():
pubsub = red.pubsub()
pubsub.subscribe('chat')
for message in pubsub.listen():
print message
yield 'data: %s\n\n' % message['data']
@app.route('/post', methods=['POST'])
def post():
message = flask.request.form['message']
user = flask.session.get('user', 'anonymous')
now = datetime.datetime.now().replace(microsecond=0).time()
red.publish('chat', u'[%s] %s: %s' % (now.isoformat(), user, message))
@app.route('/stream')
def stream():
return flask.Response(event_stream(),
mimetype="text/event-stream")
Nie trzeba używać gunicron uruchomić przykładową aplikację . Wystarczy upewnić się, aby korzystać z wątków podczas uruchamiania aplikacji, ponieważ inaczej połączenie SSE będzie blokować serwer rozwój:
if __name__ == '__main__':
app.debug = True
app.run(threaded=True)
Po stronie klienta wystarczy funkcji obsługi Javascript, która zostanie wywołana, gdy nowy wiadomość jest wypychany z serwera.
var source = new EventSource('/stream');
source.onmessage = function (event) {
alert(event.data);
};
Server-Sent Zdarzenia są supported według najnowszych przeglądarkach Firefox, Chrome i Safari. Internet Explorer nie obsługuje jeszcze Server-Sent Events, ale oczekuje się, aby wspierać ich w wersji 10. Istnieją dwa zalecane Polyfills do obsługi starszych przeglądarek
[Oto odpowiedni artykuł z zeszłego miesiąca autorstwa Armin Ronacher, głównego programisty Flascha.] (Http://lucumr.pocoo.org/2012/8/5/stateless-and-proud/) – dumbmatter
powiązane: [Strumień data with Python and Flask] (http://stackoverflow.com/q/13386681/4279) – jfs