websocket_asyncio

WebSocket 和 asyncio 指南

在这里插入图片描述

简介

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


1. 什么是 WebSocket?

  • WebSocket 是一种全双工通信协议,它通过单个持久连接实现客户端与服务端之间的实时数据交换。
  • 它非常适合需要低延迟和实时通信的应用,例如:
    • 聊天应用
    • 实时流媒体
    • 实时数据推送

WebSocket 的特点:

  1. 全双工通信。
  2. 低延迟数据传输。
  3. 持久连接。

2. 什么是 asyncio

asyncio 是 Python 提供的用于异步编程的库,能够高效处理 I/O 密集型操作。它允许在单线程中同时运行多个任务,而无需阻塞。

主要特性:

  1. 非阻塞 I/O: 执行文件或网络等任务时不会阻塞程序。
  2. 并发: 在不使用线程或进程的情况下高效处理大量任务。
  3. 事件循环: 管理异步任务的调度和执行。
  4. 任务管理: 支持协程、async/await 语法和任务调度(如 asyncio.gatherasyncio.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()

工作原理:

  1. 服务端在 localhost:12345 上监听 WebSocket 连接。
  2. 每个客户端连接由协程 handle_connection() 处理。
  3. 服务端可以异步发送和接收消息。

4. 使用 asyncio 编写 WebSocket 客户端

代码示例:

import asyncio
import websockets

async 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())

工作原理:

  1. 客户端连接到位于 localhost:12345 的 WebSocket 服务端。
  2. 客户端发送一条消息,并等待服务端的回应。

5. asyncio 在 WebSocket 编程中的作用

asyncio 为高效处理 WebSocket 通信提供了基础。以下是它在 WebSocket 服务端和客户端中的支持方式:

关键作用:

  1. 并发: 在服务端中同时处理多个客户端连接。
    • 示例:每个客户端连接作为单独的协程运行(async def)。
  2. 非阻塞 I/O: 执行 I/O 操作(例如发送/接收消息)时不会阻塞其他任务。
  3. 事件循环: 事件循环协调协程的执行,确保响应性。
  4. 任务调度:
    • 使用 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 的优势

  1. 可扩展性: 高效处理数千个连接。
  2. 低开销: 避免线程或进程的额外开销。
  3. 响应性: 快速响应 I/O 事件。
  4. 代码简洁: 使用 async/await 编写的异步代码可读性强。

7. 示例工作流:WebSocket 服务端和客户端

服务端:

  • 异步处理客户端连接。
  • 并发处理消息,并返回响应。

客户端:

  • 连接到服务端。
  • 异步发送和接收消息。

8. 常见问题与解决方法

1. 并发处理

  • 使用 asyncio.gather()asyncio.create_task() 管理多个连接。

2. 连接管理

  • 使用 try-except 块优雅地处理连接中断或错误。

3. 安全连接

  • 使用 SSL/TLS,通过提供证书和密钥配置 websockets

9. 真实案例

  1. 聊天应用: 实现实时消息传递。
  2. 实时数据推送: 如体育比分、股票价格。
  3. 协作工具: 文档实时共享编辑。
  4. 流媒体: 音频或视频流。

10. 总结

WebSocket 和 asyncio 的结合为构建实时、可扩展的应用程序提供了强大框架。利用 asyncio 的非阻塞特性,可以高效管理 WebSocket 连接,确保客户端和服务端的实时通信。

进一步阅读:

  • asyncio 官方文档
  • websockets 官方文档

此文档从基础概念到实践应用以及潜在挑战进行了全面介绍,旨在帮助理解如何使用 asyncio 和 WebSocket 进行高效编程。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

序列模型的使用示例

序列模型的使用示例 1 RNN原理1.1 序列模型的输入输出1.2 循环神经网络(RNN)1.3 RNN的公式表示2 数据的尺寸 3 PyTorch中查看RNN的参数4 PyTorch中实现RNN(1)RNN实例化(2)forward函数(3&#xf…

Hadoop学习笔记(包括hadoop3.4.0集群安装)(黑马)

Hadoop学习笔记 0-前置章节-环境准备 0.1 环境介绍 配置环境:hadoop-3.4.0,jdk-8u171-linux-x64 0.2 VMware准备Linux虚拟机 0.2.1主机名、IP、SSH免密登录 1.配置固定IP地址(root权限) 开启master,修改主机名为…

【计算机网络】Layer4-Transport layer

目录 传输层协议How demultiplexing works in transport layer(传输层如何进行分用)分用(Demultiplexing)的定义:TCP/UDP段格式: UDPUDP的特点:UDP Format端口号Trivial File Transfer Protocol…

Android Studio创建新项目并引入第三方so外部aar库驱动NFC读写器读写IC卡

本示例使用设备:https://item.taobao.com/item.htm?spma21dvs.23580594.0.0.52de2c1bbW3AUC&ftt&id615391857885 一、打开Android Studio,点击 File> New>New project 菜单,选择 要创建的项目模版,点击 Next 二、输入项目名称…

【Linux】—简单实现一个shell(myshell)

大家好呀,我是残念,希望在你看完之后,能对你有所帮助,有什么不足请指正!共同学习交流哦! 本文由:残念ing原创CSDN首发,如需要转载请通知 个人主页:残念ing-CSDN博客&…

【Python爬虫系列】_032.Scrapy_全站爬取

课 程 推 荐我 的 个 人 主 页:👉👉 失心疯的个人主页 👈👈入 门 教 程 推 荐 :👉👉 Python零基础入门教程合集 👈👈虚 拟 环 境 搭 建 :👉👉 Python项目虚拟环境(超详细讲解) 👈👈PyQt5 系 列 教 程:👉👉 Python GUI(PyQt5)教程合集 👈👈

Android通过okhttp下载文件(本文案例 下载mp4到本地,并更新到相册)

使用步骤分为两步 第一步导入 okhttp3 依赖 第二步调用本文提供的 utils 第一步这里不做说明了,直接提供第二步复制即用 DownloadUtil 中 download 为下载文件 参数说明 这里主要看你把 destFileName 下载文件名称定义为什么后缀,比如我定义为 .mp4 下…

win10配置子系统Ubuntu子系统(无需通过Windows应用市场)实际操作记录

win10配置子系统Ubuntu子系统(无需通过Windows应用市场)实际操作记录 参考教程 : win10配置子系统Ubuntu子系统(无需通过Windows应用市场) - 一佳一 - 博客园 开启虚拟机服务的 以管理员方式运行PowerShell运行命令。 &#xf…

Showrunner AI技术浅析(四):多智能体模拟

多智能体模拟技术涉及多个智能体(Agents)在虚拟环境中的行为和互动,每个智能体都有自己的属性、目标和行为规则。 1. 多智能体模拟概述 多智能体模拟技术通过模拟多个智能体在虚拟环境中的互动来生成复杂的剧情和场景。每个智能体都有其独特…

创新性融合丨卡尔曼滤波+目标检测 新突破!

2024深度学习发论文&模型涨点之——卡尔曼滤波目标检测 卡尔曼滤波是一种递归算法,用于估计线性动态系统的状态。它通过预测和更新两个步骤,结合系统模型和观测数据,来估计系统状态,并最小化估计的不确定性。 在目标检测中&am…

USB模块布局布线

1、USB接口定义 2、USB模块常规分类介绍 3、USB常用管脚定义图示 4、USB模块布局布线分析 USB3.0高速线因为速度比较高,建议走圆弧线不能走钝角 5、总结 1、CTRL鼠标中间滑轮按下可以看线的长度 2、不懂差分类和规则的设置,可以看本人写的AD基础操作…

SpringCloud系列之分布式配置中心极速入门与实践

[toc] 1、分布式配置中心简介 在实际的项目开发中,配置文件是使用比较多的,很多项目有测试环境(TEST)、开发环境(DEV)、规范的项目还有集成环境(UAT)、生产环境(PROD),每个环境就一个配置文件。 CSDN链接:SpringCloud系列之分布式…

【Vue3学习】setup语法糖中的ref,reactive,toRef,toRefs

在 Vue 3 的组合式 API(Composition API)中,ref、reactive、toRef 和 toRefs 是四个非常重要的工具函数,用于创建和管理响应式数据。 一、ref 用ref()包裹数据,返回的响应式引用对象,包含一个 .value 属性&#xff0…

解决 Git Permission denied 问题

前言 push项目时出现gitgithub.com: Permission denied (publickey). fatal: Could not read from remote repository.Please make sure you have the correct access rights and the repository exists.出现这个问题表示你在尝试将本地代码推送到GitHub时,没有提供…

React的状态管理库-Redux

核心思想:单一数据源、状态是只读的、以及使用纯函数更新状态。 组成部分 Store(存储) 应用的唯一状态容器,存储整个应用的状态树,使用 createStore() 创建。 getState():获取当前状态。dispatch(action)&#xff…

蓝卓总裁谭彰:AI+工业互联网推动制造业数字化转型

近日,新一代工业操作系统supOS6.0在2024中国5G工业互联网大会上重磅发布。 大会期间,工信部新闻宣传中心《人民邮电报》对蓝卓总裁谭彰就“工业互联网人工智能技术融合的思考”“supOS6.0的探索与实践”“未来工业互联网平台的发展方向”展开专题访谈&am…

RabbitMQ消息队列的笔记

Rabbit与Java相结合 引入依赖 <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-amqp</artifactId> </dependency> 在配置文件中编写关于rabbitmq的配置 rabbitmq:host: 192.168.190.132 /…

数据结构:贪吃蛇详解

目录 一.地图的设计 1.字符与坐标&#xff1a; 2.本地化&#xff08;头文件&#xff09;: 3.类项&#xff1a; 4.setlocale函数&#xff1a; &#xff08;1&#xff09;函数原型&#xff1a; &#xff08;2&#xff09;使用&#xff1a; 5.宽字符的打印&#xff1a; &a…

医学AI前沿进展:图像分割以及细胞分割领域的最新研究|文献速递·24-12-17

小罗碎碎念 今天推文和大家分享医学AI领域中&#xff0c;图像分割以及细胞分割方面的三个工作。 首先看一下图像分割以及细胞分割方面&#xff0c;近五年的一个论文发表情况&#xff0c;我们可以看到&#xff0c;这个领域在前几年的热度基本持平&#xff0c;到了24年迎来了一个…

Endnote | 查看文献所在分组

软件版本&#xff1a;Endnote X8 第一种方式&#xff1a; 在文献上右键——记录摘要&#xff0c;即可在弹出页面上看到自定义和智能组的分组情况。 第二种方式&#xff1a; 在菜单栏点击文献——记录摘要&#xff0c;也可以查看分组情况。 注&#xff1a; 新版本的endnote软件…