前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >SSE协议

SSE协议

作者头像
Spaceack
发布2020-11-04 14:29:38
1.4K0
发布2020-11-04 14:29:38
举报
文章被收录于专栏:编程使我快乐

介绍

服务器推送事件: Server-Sent Events, SSE

特点

  1. 仅从服务器向客户端实现单向实时通信。
  2. 实现简单,基于HTTP协议。
  3. 浏览器端有断线重连功能。
  4. 支持用户自定义消息类型。
  5. 用来传送文本, 二进制需要编码。

flask-sse 实现

flask-sse文档

前置条件

  1. 本地Redis服务器
  2. gunicorn gevent, sse是无限事件流,flask处理HTTP请求一次只能响应一个,要需要配合异步服务器使用。

实现

服务端 sse.py

代码语言:javascript
复制
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

代码语言:javascript
复制
<!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

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2020-07-01,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 介绍
    • 特点
    • flask-sse 实现
      • 前置条件
        • 实现
        相关产品与服务
        云服务器
        云服务器(Cloud Virtual Machine,CVM)提供安全可靠的弹性计算服务。 您可以实时扩展或缩减计算资源,适应变化的业务需求,并只需按实际使用的资源计费。使用 CVM 可以极大降低您的软硬件采购成本,简化 IT 运维工作。
        领券
        问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档