websocket_asyncio
WebSocket 和 asyncio
指南
简介
本指南涵盖了使用 Python 中的 websockets
库进行 WebSocket 编程的基础知识,以及 asyncio
在异步非阻塞 I/O 中的作用。它提供了构建高效 WebSocket 服务端和客户端的知识,以及 asyncio
的特性和优势。
1. 什么是 WebSocket?
- WebSocket 是一种全双工通信协议,它通过单个持久连接实现客户端与服务端之间的实时数据交换。
- 它非常适合需要低延迟和实时通信的应用,例如:
- 聊天应用
- 实时流媒体
- 实时数据推送
WebSocket 的特点:
- 全双工通信。
- 低延迟数据传输。
- 持久连接。
2. 什么是 asyncio
?
asyncio
是 Python 提供的用于异步编程的库,能够高效处理 I/O 密集型操作。它允许在单线程中同时运行多个任务,而无需阻塞。
主要特性:
- 非阻塞 I/O: 执行文件或网络等任务时不会阻塞程序。
- 并发: 在不使用线程或进程的情况下高效处理大量任务。
- 事件循环: 管理异步任务的调度和执行。
- 任务管理: 支持协程、
async/await
语法和任务调度(如asyncio.gather
和asyncio.create_task
)。
3. 使用 asyncio
编写 WebSocket 服务端
代码示例:
import asyncio
import websockets# WebSocket 处理函数
async def handle_connection(websocket, path):print("新的客户端已连接")try:async for message in websocket:print(f"接收到:{message}")await websocket.send(f"回显:{message}")except websockets.ConnectionClosed:print("客户端断开连接")# 启动 WebSocket 服务端
start_server = websockets.serve(handle_connection, "localhost", 12345)# 运行服务端
asyncio.get_event_loop().run_until_complete(start_server)
asyncio.get_event_loop().run_forever()
工作原理:
- 服务端在
localhost:12345
上监听 WebSocket 连接。 - 每个客户端连接由协程
handle_connection()
处理。 - 服务端可以异步发送和接收消息。
4. 使用 asyncio
编写 WebSocket 客户端
代码示例:
import asyncio
import websocketsasync def client():uri = "ws://localhost:12345"async with websockets.connect(uri) as websocket:await websocket.send("你好,服务端!")response = await websocket.recv()print(f"服务端回应:{response}")asyncio.run(client())
工作原理:
- 客户端连接到位于
localhost:12345
的 WebSocket 服务端。 - 客户端发送一条消息,并等待服务端的回应。
5. asyncio
在 WebSocket 编程中的作用
asyncio
为高效处理 WebSocket 通信提供了基础。以下是它在 WebSocket 服务端和客户端中的支持方式:
关键作用:
- 并发: 在服务端中同时处理多个客户端连接。
- 示例:每个客户端连接作为单独的协程运行(
async def
)。
- 示例:每个客户端连接作为单独的协程运行(
- 非阻塞 I/O: 执行 I/O 操作(例如发送/接收消息)时不会阻塞其他任务。
- 事件循环: 事件循环协调协程的执行,确保响应性。
- 任务调度:
- 使用
asyncio.create_task()
调度后台任务。 - 使用
asyncio.gather()
并发执行多个任务。
- 使用
并发 WebSocket 服务端示例:
async def handle_connection(websocket, path):async for message in websocket:print(f"接收到:{message}")await websocket.send(f"回显:{message}")start_server = websockets.serve(handle_connection, "localhost", 12345)asyncio.run(start_server)
每个客户端连接在自己的协程中运行,从而支持并发。
6. 使用 WebSocket 和 asyncio
的优势
- 可扩展性: 高效处理数千个连接。
- 低开销: 避免线程或进程的额外开销。
- 响应性: 快速响应 I/O 事件。
- 代码简洁: 使用
async/await
编写的异步代码可读性强。
7. 示例工作流:WebSocket 服务端和客户端
服务端:
- 异步处理客户端连接。
- 并发处理消息,并返回响应。
客户端:
- 连接到服务端。
- 异步发送和接收消息。
8. 常见问题与解决方法
1. 并发处理
- 使用
asyncio.gather()
或asyncio.create_task()
管理多个连接。
2. 连接管理
- 使用
try-except
块优雅地处理连接中断或错误。
3. 安全连接
- 使用 SSL/TLS,通过提供证书和密钥配置
websockets
。
9. 真实案例
- 聊天应用: 实现实时消息传递。
- 实时数据推送: 如体育比分、股票价格。
- 协作工具: 文档实时共享编辑。
- 流媒体: 音频或视频流。
10. 总结
WebSocket 和 asyncio
的结合为构建实时、可扩展的应用程序提供了强大框架。利用 asyncio
的非阻塞特性,可以高效管理 WebSocket 连接,确保客户端和服务端的实时通信。
进一步阅读:
asyncio
官方文档websockets
官方文档
此文档从基础概念到实践应用以及潜在挑战进行了全面介绍,旨在帮助理解如何使用 asyncio
和 WebSocket 进行高效编程。
相关文章:

websocket_asyncio
WebSocket 和 asyncio 指南 简介 本指南涵盖了使用 Python 中的 websockets 库进行 WebSocket 编程的基础知识,以及 asyncio 在异步非阻塞 I/O 中的作用。它提供了构建高效 WebSocket 服务端和客户端的知识,以及 asyncio 的特性和优势。 1. 什么是 WebS…...

如何在NGINX中实现基于IP的访问控制(IP黑白名单)?
大家好,我是锋哥。今天分享关于【如何在NGINX中实现基于IP的访问控制(IP黑白名单)?】面试题。希望对大家有帮助; 如何在NGINX中实现基于IP的访问控制(IP黑白名单)? 1000道 互联网大…...

Y3编辑器文档4:触发器1(界面及使用简介、变量作用域、入门案例)
文章目录 一、触发器简介1.1 触发器界面1.2 ECA语句编辑及快捷键1.3 参数设置1.4 变量设置1.5 实体触发器1.6 触发器复用 二、触发器的多层结构2.1 子触发器(在游戏内对新的事件进行注册)2.2 触发器变量作用域 三、入门案例3.1 使用触发器实现瞬间移动3.…...

echarts图表自定义配置(二)——代码封装
下图是初版,火山图的代码。可以看出,里面的变量,逻辑,函数存在冗余,基本上都是改了参数,同样的get和set,去刷新图表;对于往后继续开发十几二十个图表,会很麻烦。因此需要…...

02、10个富士胶片模拟的设置
二色彩 1、色彩的加减控制全局的饱和度增减; 2、色彩效果只提升暖色系饱和度; 3、FX蓝色大幅度提升蓝色系饱和度; 4、三个参数都不改变颜色的色相。 2.1 色彩 色彩调整的是拍摄画面整体的色彩饱和程度 2.2色彩效果 调整的是画面中暖色…...

鸿蒙系统-前端0帧起手
鸿蒙系统-前端0帧起手 先search 一番 找到对应的入门文档1. 运行项目遇到问题 如下 (手动设计npm 的 registry 运行 npm config set registry https://registry.npmjs.org/)2.运行后不支持一些模拟器 配置一下(如下图,运行成功&am…...

211-基于FMC的1路1.5G ADC 1路 2.5G DAC子卡
一、板卡概述 FMC-1AD-1DA-1SYNC是我司自主研发的一款1路1G AD采集、1路2.5G DA回放的FMC、1路AD同步信号子卡。板卡采用标准FMC子卡架构,可方便地与其他FMC板卡实现高速互联,可广泛用于高频模拟信号采集等领域。 二、功能介绍 2.1 原理框图 2.2 硬件…...

获取微信用户openid
附上开发文档:https://developers.weixin.qq.com/doc/offiaccount/OA_Web_Apps/Wechat_webpage_authorization.html 开发之前,准备事项 一个已认证过的服务号|基本信息配置js域名和网站授权域名配置最后确认当前账号网页授权功能是否开通,没有开通的无法获取到用户授权开发人…...

MultiRECloudSim使用
MultiRECloudSim使用 简介 MultiRECloudSim是一个用于云计算环境下的模拟器相关工具,它主要用于模拟和评估云计算中的资源分配、任务调度等多种场景。它可能是基于CloudSim这个基础的云计算模拟器进行扩展而来,CloudSim提供了基本的云计算模拟功能,如数据中心、虚拟机、任务…...

智能设备安全-固件逆向分析
固件逆向分析实验报告-20241022 使用固件常用逆向分析工具,对提供的固件进行文件系统提取,并记录逆向分析实验过程,提交实验报告(报告要求图文并茂,对涉及到的关键步骤附截图说明)。具体任务如下࿱…...

【小白包会的】使用supervisor 管理docker内多进程
使用supervisor 管理docker内多进程 一般情况下,一个docker是仅仅运行一个服务的 但是有的情况中,希望一个docker中运行多个进程,运行多个服务,也就是一个docker容器执行多个服务。 调研了一下,发现可以通过**super…...

使用navicat新旧版本,连接PostgreSQL高版本报错问题图文解决办法
使用navicat新旧版本,连接PostgreSQL高版本报错问题图文解决办法 一、问题现象:二、出现原因三、解决方法:1、升级Navicat版本:2、使用低版本的postgreSQL:3、修改Navicat的dll二进制文件:navicat版本15nav…...

IDEA 未启用lombok插件的Bug
项目中maven已引用了lombok依赖,之前运行没有问题的,但有时启动会提示: java: You arent using a compiler supported by lombok, so lombok will not work and has been disabled. Your processor is: com.sun.proxy.$Proxy8 Lombok support…...

认识GO--gRPC的metadata
参考: 写给go开发者的gRPC教程-metadata-CSDN博客https://blog.csdn.net/kevin_tech/article/details/129395177?ops_request_misc%257B%2522request%255Fid%2522%253A%25221f2f2e26f48c755c33344ccb171a49fc%2522%252C%2522scm%2522%253A%252220140713.130102334…...

2024年安徽省职业院校技能大赛信息安全管理与评估
一、赛项名称 赛项名称:信息安全管理与评估 英文名称:Information Security Management and Evaluation 赛项组别:高职组 赛项归属:电子信息大类 二、竞赛目标 通过赛项检验参赛选手熟悉信息安全行业标准规范和信息 安全测试员新职…...

Perl 引用
Perl 引用 Perl,作为一种灵活而强大的编程语言,广泛用于系统管理、网络编程、GUI开发等领域。在Perl编程中,引用(References)是一个核心概念,它允许变量引用其他数据,从而创建复杂的数据结构&a…...

RT-Thread启动过程 :从汇编开始的启动流程
这个系列参考了《嵌入式实时操作系统RT-Thread设计与实现》,会详细介绍RT-Thread的启动流程,即是如何从零开始在开发板上运行起一个RTOS内核的。本文将会以 ch32v307VCT6 开发板为例展开进行详细介绍。主要包括:startup.S、初始化与系统相关的…...

Scala—“==“和“equals“用法(附与Java对比)
Scala 字符串比较—""和"equals"用法 Scala 的 在 Scala 中, 是一个方法调用,实际上等价于调用 equals 方法。不仅适用于字符串,还可以用于任何类型,并且自动处理 null。 Demo: Java 的 在 J…...

$route和$router的区别
在 Vue.js 中,$route 和 $router 都是 Vue Router 提供的对象,但它们有不同的用途和功能。 1. $router $router 是 Vue Router 实例的引用,它允许你通过 JavaScript 进行路由的控制和导航。你可以通过 $router 来执行路由的操作,…...

[工具升级问题] 钉钉(linux版)升级带来的小麻烦
本文由Markdown语法编辑器编辑完成。 1. 背景: 今日钉钉又发布了新的升级版本。由于我工作时使用的是Ubuntu 20.04版本,收到的升级推送信息是,可以升级到最新的7.6.25-Release版本。根据钉钉官方给出的历次更新版说明,这个新的版本…...

Leetcode经典题13--接雨水
题目描述 给定 n 个非负整数表示每个宽度为 1 的柱子的高度图,计算按此排列的柱子,下雨之后能接多少雨水。 输入输出示例 输入:height [0,1,0,2,1,0,1,3,2,1,2,1] 输出:6 解释:上面是由数组 [0,1,0,2,1,0,1,3,2,1,2,1…...

yarn修改缓存位置
查看缓存位置 以下三个命令分别为:bin是yarn存储命令的二进制文件,global存储全局node_modules ,cache存储用下下载缓存,查看本机目前的目录: 查看bin目录命令:yarn global bin 查看global目录命令&…...

OpenHarmony-3.HDF input子系统(5)
HDF input 子系统OpenHarmony-4.0-Release 1.Input 概述 输入设备是用户与计算机系统进行人机交互的主要装置之一,是用户与计算机或者其他设备通信的桥梁。常见的输入设备有键盘、鼠标、游戏杆、触摸屏等。本文档将介绍基于 HDF_Input 模型的触摸屏器件 IC 为 GT91…...

RabbitMQ 消息持久化/镜像队列/lazy对时延影响
测试背景: 不同条件下RabbitMQ不同队列类型的生产时延测试: 测试环境: 机型:rabbimtq.2u4g.cluster 背景流量:1000 TPS 测试条件: 消息大小 4k,消息条数为1000条,时延取值为平均…...

【深度学习】深刻理解Swin Transformer
Swin Transformer 是一种基于 Transformer 的视觉模型,由 Microsoft 研究团队提出,旨在解决传统 Transformer 模型在计算机视觉任务中的高计算复杂度问题。其全称是 Shifted Window Transformer,通过引入分层架构和滑动窗口机制,S…...

[2015~2024]SmartMediaKit音视频直播技术演进之路
技术背景 2015年,因应急指挥项目需求,我们实现了RTMP推送音视频采集推送(采集摄像头和麦克风数据)模块,在我们做好了RTMP推送模块后,苦于没有一个满足我们毫秒级延迟诉求的RTMP播放器,于是第一…...

redis 使用Lettuce 当redis挂掉重启之后 网络是怎么重新连接
Lettuce是一个高性能的Java Redis客户端,支持同步、异步和反应式编程模式 Lettuce的核心功能包括: 高性能:通过使用Netty作为底层网络通信框架,实现了非阻塞IO,提高了性能。丰富的API:提供了丰富…...

【IntelliJ IDEA 集成工具】TalkX - AI编程助手
前言 在数字化时代,技术的迅猛发展给软件开发者带来了更多的挑战和机遇。为了提高技术开发群体在繁多项目中的编码效率和质量,他们需要一个强大而专业的工具来辅助开发过程,而正是为了满足这一需求,TalkX 应运而生。 一、概述 1…...

二叉搜索树Ⅲ【东北大学oj数据结构8-3】C++
二叉搜索树 III B:在二叉搜索树II中加入delete指令,创建程序对二叉搜索树T执行如下指令。 插入 k:将key k 插入到 T 中。 find k:报告T中是否存在key k。 delete k:删除key为 k 的节点。 打印:使用中序树遍…...

【面试笔记】CPU 缓存机制
CPU 缓存机制 1. CPU Cache 与 MMU1.1 MMU 是什么?TLB 又是什么?他们是怎么工作的?2.2 简述 Cache 与 MMU 的协作关系?2.3 简述 Cache 与 MMU 的协作工作流程? 2. CPU 多层次缓存2.1 什么是 CPU 的多层次缓存结构&…...