介绍
服务器推送事件: Server-Sent Events, SSE
特点
- 仅从服务器向客户端实现单向实时通信。
- 实现简单,基于HTTP协议。
- 浏览器端有断线重连功能。
- 支持用户自定义消息类型。
- 用来传送文本, 二进制需要编码。
flask-sse 实现
flask-sse文档
前置条件
- 本地Redis服务器
- gunicorn gevent, sse是无限事件流,flask处理HTTP请求一次只能响应一个,要需要配合异步服务器使用。
实现
服务端 sse.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
from flask import Flask, render_template
from flask_sse import sse
app = Flask(__name__)
app.config["REDIS_URL"] = "redis://localhost"
app.register_blueprint(sse, url_prefix='/stream')
@app.route('/')
def index():
return render_template("index.html")
@app.route('/hello')
def publish_hello():
sse.publish({"message": "Hello!"}, type='greeting')
return "Message sent!"
|
客户端
templates/index.html
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
<!DOCTYPE html>
<html>
<head>
<title>Flask-SSE Quickstart</title>
</head>
<body>
<h1>Flask-SSE Quickstart</h1>
<script>
var source = new EventSource("{{ url_for('sse.stream') }}");
source.addEventListener('greeting', function(event) {
var data = JSON.parse(event.data);
console.log("The server says " + data.message);
}, false);
source.addEventListener('error', function(event) {
console.log("Failed to connect to event stream. Is Redis running?");
}, false);
</script>
</body>
</html>
|
gunicorn sse:app --worker-class gevent --bind 127.0.0.1:8000