使用Sanic和SSE实现实时股票行情推送

news2025/1/23 10:20:48

💝💝💝欢迎莅临我的博客,很高兴能够在这里和您见面!希望您在这里可以感受到一份轻松愉快的氛围,不仅可以获得有趣的内容和知识,也可以畅所欲言、分享您的想法和见解。
在这里插入图片描述

  • 推荐:「stormsha的主页」👈,「stormsha的知识库」👈持续学习,不断总结,共同进步,为了踏实,做好当下事儿~

  • 专栏导航

    • Python系列: Python面试题合集,剑指大厂
    • Git系列: Git操作技巧
    • GO系列: 记录博主学习GO语言的笔记,该笔记专栏尽量写的试用所有入门GO语言的初学者
    • 数据库系列: 详细总结了常用数据库 mysql 技术点,以及工作中遇到的 mysql 问题等
    • 运维系列: 总结好用的命令,高效开发
    • 算法与数据结构系列: 总结数据结构和算法,不同类型针对性训练,提升编程思维

    非常期待和您一起在这个小小的网络世界里共同探索、学习和成长。💝💝💝 ✨✨ 欢迎订阅本专栏 ✨✨

    💖The Start💖点点关注,收藏不迷路💖

    📒文章目录

      • 什么是Server-Sent Events (SSE)
      • 为什么选择Sanic
      • 实现步骤
        • 1. 安装依赖
        • 2. 创建Sanic应用
        • 3. 前端实现
        • 4. 避免跨域问题
        • 5. 优化与扩展
      • 总结


实时数据推送已经成为了许多应用的关键功能之一,尤其是在金融、监控、社交媒体等领域。本文将深入探讨如何使用Sanic框架结合Server-Sent Events (SSE)技术,实现用户在浏览器中选择不同股票并实时接收对应的股票行情推送。本文将重点介绍实现步骤、技术细节以及实际使用中的一些优化建议。

在这里插入图片描述

什么是Server-Sent Events (SSE)

Server-Sent Events (SSE) 是一种轻量级的服务器推送技术,允许服务器向客户端推送数据。与WebSocket相比,SSE相对简单,特别适合需要单向数据流的应用场景,比如新闻推送、股票行情、实时通知等。

SSE的优势包括:

  1. 简单易用:使用HTTP协议,无需复杂的握手过程。
  2. 自动重连:浏览器原生支持自动重连机制,当连接断开时,客户端会自动尝试重新连接。
  3. 轻量级:非常适合频繁的数据推送,尤其是在数据更新频率较高的场景中。

为什么选择Sanic

Sanic是一个基于Python的异步Web框架,以其高性能和简单易用的API广受欢迎。Sanic天然支持异步操作,特别适合处理SSE这样的长连接请求。

使用Sanic和SSE的结合,可以轻松地实现高效的实时数据推送服务,特别是在股票行情等对实时性要求高的场景下。

实现步骤

接下来,我们将一步步实现一个简单的实时股票行情推送服务,用户可以在浏览器中选择股票并接收对应的实时行情。

1. 安装依赖

首先,确保已安装Sanic和其他必要的库。可以通过以下命令安装:

pip install sanic

2. 创建Sanic应用

接下来,创建一个Sanic应用,并实现一个简单的SSE数据流。我们将模拟几个股票的实时数据,并根据用户的选择推送相应的股票行情。

from sanic import Sanic, response
import asyncio
import time

app = Sanic("StockSSE")

# 模拟股票行情数据
stock_data = {
    "AAPL": {"stock_name": "Apple", "price": 150.00, "change": 0.25},
    "GOOG": {"stock_name": "Google", "price": 2750.00, "change": -10.00},
    "AMZN": {"stock_name": "Amazon", "price": 3400.00, "change": 15.00}
}

async def stock_data_generator(stock_symbol):
    while True:
        data = stock_data.get(stock_symbol, {})
        data['timestamp'] = time.time()
        yield f"data: {response.json(data)}\n\n"
        await asyncio.sleep(1)

@app.route("/stock/<stock_symbol>")
async def stock_stream(request, stock_symbol):
    
    async def stock_stream(res):
        async for data in stock_data_generator(stock_symbol):
            await res.write(data)
    return response.stream(stock_stream, content_type='text/event-stream')

if __name__ == "__main__":
    app.run(host="0.0.0.0", port=8000)

在这个示例中,我们定义了一个简单的股票数据模拟器,并使用/stock/<stock_symbol>路由来处理SSE请求。通过stock_data_generator生成器函数,我们可以持续不断地向客户端推送股票数据。

3. 前端实现

前端使用HTML和JavaScript的EventSource对象来接收服务器推送的数据,并根据用户选择的股票更新显示内容。以下是一个简单的HTML页面,用户可以选择股票,并实时查看对应的行情。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>实时股票行情</title>
    <style>
        body {
            font-family: Arial, sans-serif;
        }
        .stock-data {
            margin: 20px;
            padding: 10px;
            border: 1px solid #ddd;
        }
        select {
            margin: 20px;
            padding: 5px;
        }
    </style>
</head>
<body>
    <h1>实时股票行情</h1>
    <select id="stock-select">
        <option value="Apple">Apple</option>
        <option value="GOOG">Google</option>
        <option value="AMZN">Amazon</option>
    </select>
    <div id="stock-container">
        <div class="stock-data" id="stock-data">选择一个股票查看其行情数据...</div>
    </div>

    <script>
        let eventSource;

        const stockSelect = document.getElementById('stock-select');
        const stockDataDiv = document.getElementById('stock-data');

        function updateStock(stockSymbol) {
            if (eventSource) {
                eventSource.close();
            }
            eventSource = new EventSource(`/stock/${stockSymbol}`);

            eventSource.onmessage = function(event) {
                const stockData = JSON.parse(event.data);
                stockDataDiv.innerHTML = `
                    股票名称: ${stockData.stock_name}<br>
                    当前价格: ${stockData.price}<br>
                    涨跌幅: ${stockData.change}<br>
                    时间戳: ${stockData.timestamp}<br>
                `;
            };

            eventSource.onerror = function(event) {
                console.error('SSE 连接错误:', event);
            };
        }

        stockSelect.addEventListener('change', function() {
            const selectedSymbol = stockSelect.value;
            updateStock(selectedSymbol);
        });

        // 初始化加载第一个股票的数据
        updateStock(stockSelect.value);
    </script>
</body>
</html>

这个前端页面非常简单,通过JavaScript监听股票选择器的变化,并根据用户选择的股票启动新的SSE连接,实时更新行情数据。

4. 避免跨域问题

在实际应用中,跨域请求可能会导致浏览器拒绝连接。如果前端与后端不在同一个域下,可以使用Sanic的file函数直接返回HTML页面,确保所有请求都来自同一域,从而避免跨域问题。

from sanic import response
@app.route("/")
async def index(request):
    return await response.file('static/index.html')

将HTML文件放置在static目录下,并通过Sanic的路由直接返回该文件。这样,前端页面和数据请求都运行在同一个域下,消除了跨域问题。

5. 优化与扩展

在实际项目中,以下几点优化建议可以帮助你进一步提升系统的性能和用户体验:

  1. 数据源优化: 如果需要处理真实的股票数据,可以将get_stock_data函数扩展为从外部API获取实时数据。
  2. 推送频率: 根据业务需求,调整数据推送的频率,或者仅在数据发生变化时推送更新,以减少不必要的流量和资源占用。
  3. 错误处理: 添加错误处理机制,如在SSE连接断开时提供用户友好的提示,或在数据请求失败时进行重试。
  4. 负载均衡: 在高并发场景下,可以使用Nginx等反向代理服务器对Sanic服务进行负载均衡,确保服务的稳定性和高可用性。

总结

通过本文的介绍,开发者可以轻松实现一个基于Sanic和SSE的实时股票行情推送服务。该技术方案不仅简单高效,而且能够满足金融应用中对实时数据推送的高要求。在实际应用中,通过合理的优化和扩展,可以构建出性能卓越、用户体验良好的实时数据推送系统。

希望这篇文章能为你在实际开发中提供有价值的参考。未来,你可以将这些技术应用到更多的实时数据场景中,如新闻推送、社交媒体通知、监控报警等,为用户提供更加动态和互动的体验。


🔥🔥🔥道阻且长,行则将至,让我们一起加油吧!🌙🌙🌙

💖The End💖点点关注,收藏不迷路💖

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2036526.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【Next】全局样式和局部样式

不同于 nuxt &#xff0c;next 的样式绝大部分都需要手动导入。 全局样式 使用 sass 先安装 npm i sass -D 。 我们可以定义一个 styles 文件&#xff0c;存放全局样式。 variables.scss $fs30: 30px;mixin border() {border: 1px solid red; }main.scss use ./variables …

业界首个OpenTelemetry结合eBPF的向导式可观测性平台APO正式开源

AutoPilot Observability (简称APO&#xff09;是什么&#xff1f; 开箱即用的可观测性平台&#xff1a;APO 致力于提供一键安装、开箱即用的可观测性平台。APO 的 OneAgent 支持一键免配置安装 Tracing 探针&#xff0c;支持采集应用的故障现场日志、基础设施指标、应用和下游…

主机防火墙IPV6 域名 测试环境搭建及测试方法

由于国内当前网站支持ipv6的很少,部分支持ipv6 的网站由于路由器的限制,也无法直接访通过ipv6进行访问,因此进行主机防火墙ipv6域名测试时,需要自己搭建环境进行测试,以下为搭建环境的步骤。 1 . 搭建DNS服务器 环境:安装有python,系统为Windows Server 2016 DNS服务…

【Vue3】vue模板中如何使用enum枚举类型

简言 有的时候&#xff0c;我们想在vue模板中直接使用枚举类型的值&#xff0c;来做一些判断。 ts枚举 枚举允许开发人员定义一组命名常量。使用枚举可以更容易地记录意图&#xff0c;或创建一组不同的情况。TypeScript 提供了基于数字和字符串的枚举。 枚举的定义这里不说了…

haproxy最强攻略

1、负载均衡 负载均衡&#xff08;Load Balance&#xff0c;简称 LB&#xff09;是高并发、高可用系统必不可少的关键组件&#xff0c;目标是 尽力将网络流量平均分发到多个服务器上&#xff0c;以提高系统整体的响应速度和可用性。 负载均衡的主要作用如下&#xff1a; 高并发…

接入谷歌支付配置

1.谷歌云创建项目 网址&#xff1a;https://console.cloud.google.com/ 按照步骤创建即可 创建好后选择项目&#xff0c;转到项目设置 选择服务账户&#xff0c;选择创建新的服务账户 名称输入好后访问权限吗账号权限都可以不用填写&#xff0c;默认就好了 然后点击电子邮…

爵士编曲:Bass编写,Walking Bass,SwingBass 爵士鼓 Swing Jazz律动 Moonkits

Walking Bass Line是乐曲构造中的基垫&#xff0c;“Walking”是在BassLine中的一种重要的感觉构成&#xff0c;等同于我们对于“行走”的理解&#xff0c;意义就是“一步接着一步”&#xff0c;先从每一步&#xff08;每一小节&#xff09;建立&#xff0c;并持续构建成一个完…

Android 10.0 SystemUI下拉状态栏QSTileView去掉着色效果显示彩色图标功能实现

1.前言 在10.0的系统rom定制化开发中,在关于SystemUI的下拉状态栏中QSTileView的背景颜色设置过程中,在由于 系统原生有着色效果,导致现在某些彩色背景显示不是很清楚效果不好,所以需要去掉QSTileView的默认着色 背景显示原生的彩色背景,接下来就来实现相关功能 如图: 2.…

【微信小程序】实现中英文切换

1、组织语言资源 创建两个文件夹&#xff0c;分别用于存放中文和英文的语言资源。例如&#xff0c;可以在 utils 文件夹下创建 lang 文件夹&#xff0c;然后在其中创建 zh.js 和 en.js 文件&#xff0c;分别存放中文和英文的文本内容。 zh.js: const zh {home: {title: 这里…

【人工智能】全景解析:【机器学习】【深度学习】从基础理论到应用前景的【深度探索】

目录 1. 人工智能的基本概念 1.1 人工智能的定义与发展 1.1.1 人工智能的定义 1.1.2 人工智能的发展历史 1.2 人工智能的分类 1.2.1 弱人工智能 1.2.2 强人工智能 1.2.3 超人工智能 1.3 人工智能的关键组成部分 1.3.1 数据 1.3.2 算法 1.3.3 计算能力 2. 机器学习…

大模型系列6--神经网络(WIP)

神经网络 1. 背景2. 理论知识2.1. 单个神经元2.1.1. 基础2.1.2. 神经元激活代码 2.2. 多个神经元2.2.1. 基础2.2.2. 神经元激活代码2.2.3. 反向传播 3. 神经网络编程基础3.1. 基本概念3.2. 逻辑回归3.3. 梯度下降法(Gradient Descent)3.3.1. 基础知识3.3.2. 梯度下降的形式化说…

Selenium + Python 自动化测试09(多窗口切换)

我们的目标是&#xff1a;按照这一套资料学习下来&#xff0c;大家可以独立完成自动化测试的任务。 上一篇我们讨论了截图的操作方法&#xff0c;本篇文章我们讲述一下多窗口切换的操作方法。 在实际的测试项目组中我们可能会遇到多窗口的情况&#xff0c;有时候需要在不同窗口…

MyBatis 配置与测试方式

目录 一&#xff0c;什么是MyBatis 二&#xff0c;准备工作 创建项目 配置数据库连接 持久层代码 单元测试 一&#xff0c;什么是MyBatis 简单来说&#xff0c;MyBatis 是一款优秀的持久层框架&#xff0c;用于简化JDBC的开发&#xff0c;能更简单完成程序与数据库之间…

MySQL 复制建表、操作补充、pymysql操作—/—<10>

一、复制建表 1、复制其他表的结构 只复制结构&#xff0c;不复制值 CREATE TABLE aaa LIKE student student表&#xff1a; 复制完的a表&#xff1a; 2、复制查询结果并建表: create table a (select id,sum(score) as sum_sco from score group by id) score表结构如图所…

【存储学习笔记】3:备份(Backup)技术分类

1 定义 备份&#xff1a;出于数据恢复的目的而创建一份额外的数据副本。 2 技术指标 2.1 备份窗口&#xff08;Backup Window&#xff09; 从定指标的角度&#xff1a;可以安全地实施备份的时间 从实现指标的角度&#xff1a;备份操作所需的时间 2.2 恢复时间目标&#xf…

C 408—《数据结构》算法题基础篇—数组(通俗易懂)

目录 Δ前言 一、数组的合并 0.题目&#xff1a; 1.算法设计思想&#xff1a; 2.C语言描述&#xff1a; 3.算法的时间和空间复杂度 : 二、数组元素的倒置 0.题目 : 1.算法设计思想 : 2.C语言描述 : 3.算法的时间和空间复杂度 : 三、数组中特定值元素的删除 0.题目 : …

贷齐乐案例

源码分析&#xff1a; <?php // 设置 HTTP 头部&#xff0c;指定内容类型为 text/html&#xff0c;字符集为 utf-8 header("Content-type: text/html; charsetutf-8"); // 引入数据库配置文件 require db.inc.php; // 定义函数 dhtmlspecialchars&#xff0c;用…

基于WOA鲸鱼优化的GroupCNN分组卷积网络时间序列预测算法matlab仿真

目录 1.算法运行效果图预览 2.算法运行软件版本 3.部分核心程序 4.算法理论概述 4.1 分组卷积神经网络&#xff08;GroupCNN&#xff09; 4.2 WOA优化算法 5.算法完整程序工程 1.算法运行效果图预览 (完整程序运行后无水印) 2.算法运行软件版本 matlab2022a 3.部分核…

获奖方案|趋动科技:资源池化释放AI算力价值

“据统计&#xff0c;GPU的平均利用率不超过30%&#xff0c;会产生巨大的算力资源浪费。我们用软件定义的方式通常可以把用户GPU的利用率提升3-8倍&#xff0c;甚至可以到10倍。” 这是算力池化软件公司趋动科技援引行业报告数据并结合自身企业最佳实践经验给出的最新数据。通…

分布式版本控制概述

目录 1. 版本控制软件的基础功能 2. 集中式版本控制 3. 分布式版本控制 git 是分布式管理控制工具&#xff0c;用来管理开发项目中的资源: 这样的软件在项目管理开发中称为 SCM&#xff08;Software Configuration Management&#xff09; 软件; 下面是版本控制到分布式版本…