Python 异步套接字编程

异步套接字编程是异步编程在网络通信中的应用,它使用异步 IO 操作和事件循环来实现高并发的网络应用。Python 中的 asyncio 模块提供了对异步套接字编程的支持,以下是异步套接字编程的一些重要概念和使用方法:

1. 异步套接字服务器:

异步套接字服务器通过 asyncio.start_server() 函数创建,该函数返回一个 asyncio.Server 对象,它是一个异步迭代器,可以在事件循环中进行迭代。

import asyncioasync def handle_client(reader, writer):data = await reader.read(100)message = data.decode()addr = writer.get_extra_info('peername')print(f"Received {message} from {addr}")print("Send: %r" % message)writer.write(data)await writer.drain()print("Closing the connection")writer.close()async def main():server = await asyncio.start_server(handle_client, '127.0.0.1', 8888)addr = server.sockets[0].getsockname()print(f'Serving on {addr}')async with server:await server.serve_forever()asyncio.run(main())

在上述代码中,handle_client 函数是一个协程,用于处理客户端连接。asyncio.start_server() 创建一个异步套接字服务器,监听指定的地址和端口。通过 await server.serve_forever() 使服务器一直运行。

2. 异步套接字客户端:

异步套接字客户端使用 asyncio.open_connection() 函数创建,返回一个由 (reader, writer) 组成的元组。

import asyncioasync def send_message(message):reader, writer = await asyncio.open_connection('127.0.0.1', 8888)print(f'Send: {message!r}')writer.write(message.encode())data = await reader.read(100)print(f'Received: {data.decode()!r}')print('Closing the connection')writer.close()asyncio.run(send_message("Hello, server!"))

在上述代码中,send_message 函数是一个协程,使用 asyncio.open_connection() 函数创建一个异步套接字客户端。通过协程中的异步 IO 操作实现数据的发送和接收。

3. 异步套接字的异常处理:

在异步套接字编程中,需要特别关注异常的处理。例如,在服务器中,可能需要处理客户端连接中断的情况:

async def handle_client(reader, writer):try:data = await reader.read(100)# 处理数据except asyncio.CancelledError:print("Client connection was cancelled.")except Exception as e:print(f"An error occurred: {e}")finally:writer.close()async def main():server = await asyncio.start_server(handle_client, '127.0.0.1', 8888)addr = server.sockets[0].getsockname()print(f'Serving on {addr}')async with server:await server.serve_forever()asyncio.run(main())

4. 异步套接字的超时处理:

在异步套接字编程中,有时需要设置超时时间,以防止长时间等待某个操作完成。可以使用 asyncio.wait_for() 函数来设置超时。

import asyncioasync def send_message_with_timeout(message):try:reader, writer = await asyncio.open_connection('127.0.0.1', 8888)await asyncio.wait_for(writer.write(message.encode()), timeout=5)data = await asyncio.wait_for(reader.read(100), timeout=5)print(f'Received: {data.decode()!r}')except asyncio.TimeoutError:print("Operation timed out.")except Exception as e:print(f"An error occurred: {e}")finally:writer.close()asyncio.run(send_message_with_timeout("Hello, server!"))

5. 异步套接字编程中的并发处理:

异步套接字编程充分利用事件循环和协程的特性,可以在单个线程中有效地处理大量并发连接。这通过异步 IO 操作的非阻塞特性实现。以下是一个简单的示例,展示如何在异步套接字服务器中处理多个并发连接:  //handle_client 函数是一个协程,用于处理单个客户端连接。由于协程的非阻塞特性,事件循环可以同时处理多个连接,而不会阻塞等待 IO 操作完成。

import asyncioasync def handle_client(reader, writer):try:data = await reader.read(100)message = data.decode()addr = writer.get_extra_info('peername')print(f"Received {message} from {addr}")print("Send: %r" % message)writer.write(data)await writer.drain()print("Closing the connection")except asyncio.CancelledError:print("Client connection was cancelled.")except Exception as e:print(f"An error occurred: {e}")finally:writer.close()async def main():server = await asyncio.start_server(handle_client, '127.0.0.1', 8888)addr = server.sockets[0].getsockname()print(f'Serving on {addr}')async with server:await server.serve_forever()asyncio.run(main())

6. 高级概念 - SSL/TLS 加密:

异步套接字编程也支持通过 SSL/TLS 进行安全的加密通信。可以使用 asyncio.start_server()asyncio.open_connection()ssl 参数来实现。

以下是一个简单的示例,演示了如何在异步套接字服务器和客户端中使用 SSL/TLS 加密:

 

import asyncio
import sslasync def handle_client(reader, writer):# 处理客户端连接# ...async def main():# 服务器端 SSL/TLS 设置ssl_context = ssl.create_default_context(ssl.Purpose.CLIENT_AUTH)ssl_context.load_cert_chain(certfile='server.crt', keyfile='server.key')server = await asyncio.start_server(handle_client, '127.0.0.1', 8888, ssl=ssl_context)addr = server.sockets[0].getsockname()print(f'Serving on {addr}')async with server:await server.serve_forever()asyncio.run(main())

在客户端中也可以使用 ssl 参数,通过 ssl.create_default_context() 创建 SSL/TLS 上下文。

import asyncio
import sslasync def send_message(message):# 客户端 SSL/TLS 设置ssl_context = ssl.create_default_context(ssl.Purpose.SERVER_AUTH)ssl_context.load_verify_locations('server.crt')reader, writer = await asyncio.open_connection('127.0.0.1', 8888, ssl=ssl_context)# 发送和接收数据# ...asyncio.run(send_message("Hello, server!"))

7.总结:

异步套接字编程通过充分利用异步 IO 操作和事件循环的特性,可以在网络编程中实现高效的并发处理。这使得程序能够有效地处理大量的并发连接,提高了性能和资源利用率。在编写异步套接字编程代码时,需要关注异常处理、超时处理以及其他安全性和性能方面的考虑。

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

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

相关文章

git与ssh多账户共存

git与ssh多账户共存 前言git多账户ssh多公钥参考 前言 在使用git与ssh时,经常会遇到多个账户共存的情况 例如使用不同的公钥登陆到不同的服务;使用不同的git信息进行commit git多账户 在默认情况下 git的信息存在 ~/.gitconfig 可以使用命令查看 git…

关于elementui和ant design vue无法禁止浏览器自动填充问题

以and design vue 为例&#xff1a; 图标用来显隐账号密码 html&#xff1a; <a-form-model-item label"账号密码:" prop"password"><a-input v-if"passwordTab" ref"passwordInput" v-model"form.password" typ…

详解最长公共子序列问题(三种方法)

这里&#xff0c;为了更方便地解释&#xff0c;我以洛谷上的一道典型题目为例&#xff0c;为大家讲解处理最长公共子序列问题的几种常见方法。这道题目中规定了两个子序列的长度相等&#xff0c;如果遇到不等的情况&#xff0c;也只需要对长度稍作修改即可&#xff0c;算法思想…

qs-一个序列化和反序列化的JavaScript库

起因 一个业务场景中&#xff0c;最终得到一串字符"status[0]value1&status[1]value2" 通过解析&#xff0c;理应得到一个数组&#xff0c;却得到一个对象 于是展开问题排查 最终发现是qs.parse 这个地方出了问题 排查结果 qs解析这种带下标的字符串时&#xff…

基于python的NBA球员数据可视化分析的设计与实现

完整下载&#xff1a;基于python的NBA球员数据可视化分析的设计与实现.docx 基于python的NBA球员数据可视化分析的设计与实现 Design and Implementation of NBA Player Data Visualization Analysis based on Python 目录 目录 2 摘要 3 关键词 4 第一章 引言 4 1.1 研究背景 …

【Java 进阶篇】Redis 命令操作:轻松掌握基本操作

Redis是一款高性能的键值对存储系统&#xff0c;以其快速、灵活的特性而备受开发者推崇。本文将详细介绍Redis的基本命令操作&#xff0c;包括键值操作、数据查询、事务处理等方面&#xff0c;帮助初学者更好地理解和使用Redis。 基本命令 1. 键值操作 1.1 SET&#xff1a;设…

spark shuffle 剖析

ShuffleExchangeExec private lazy val writeMetrics SQLShuffleWriteMetricsReporter.createShuffleWriteMetrics(sparkContext)private[sql] lazy val readMetrics SQLShuffleReadMetricsReporter.createShuffleReadMetrics(sparkContext)用在了两个地方&#xff0c;承接的是…

目标检测YOLO系列从入门到精通技术详解100篇-【目标检测】SLAM(基础篇)(三)

目录 前言 移动机器人视觉SLAM回环检测 01 回环检测问题描述 02 主流回环检测方法 2.1 根据路标点先验信息

【Flink】Standalone运行模式

独立模式是独立运行的&#xff0c;不依赖任何外部的资源管理平台&#xff1b;当然独立也是有代价的&#xff1a;如果资源不足&#xff0c;或者出现故障&#xff0c;没有自动扩展或重分配资源的保证&#xff0c;必须手动处理。所以独立模式一般只用在开发测试或作业非常少的场景…

Ps:参考线

参考线 Guides用于帮助精确地定位图像或元素&#xff0c;显示为浮动在图像上的非打印线&#xff0c;可以移动或移除&#xff0c;还可以临时锁定。 Ps 中的参考线可分为三大类&#xff1a;画布参考线、画板参考线和智能参考线。 可在“首选项/参考线、网格和切片”中设置参考线的…

C 标准库 - <stddef.h>和<stdio.h>详解

目录 C 标准库 - 简介 库变量 库宏 实例 C 标准库 - 简介 库变量 库宏 库函数 实例 C 标准库 - <stddef.h> 简介 <stdio.h> 是 C 语言中的一个标准库&#xff0c;它提供了一些常用的函数和类型定义&#xff0c;用于处理与大小相关的操作。 库变量 …

深信服防火墙路由模式开局部署-手把手教学(小白篇)

PS&#xff1a;深信服的设备只有400能够通过console连接&#xff0c;一般用户是无法连接的&#xff0c;所以大家不要妄想着从Console连接设备了&#xff0c;开局就通过MANAGE进入Web就可以 接通电源后&#xff0c;开机拿一根网线&#xff0c;一端连接防火墙的MANAGE口&#xf…

uniapp uni.navigateBack返回后刷新页面数据

方法1: 父页面设置钩子函数(onBackPress): 页面简介 | uni-app官网 适用于刷新多处数据 onBackPress(options) {this.refreshData(); }, methods:{refreshData: function() {//加载数据}, }, 方法2: 返回加success回调 uni.navigateBack({delta: 1, //返回层数&#xff0…

【C++】泛型编程 ⑭ ( 类模板示例 - 数组类模板 | 容器思想 | 自定义类可拷贝 - 深拷贝与浅拷贝 | 自定义类可打印 - 左移运算符重载 )

文章目录 一、容器思想1、自定义类可拷贝 - 深拷贝与浅拷贝2、自定义类可拷贝 - 代码示例3、自定义类可打印 - 左移运算符重载 二、代码示例1、Array.h 头文件2、Array.cpp 代码文件3、Test.cpp 主函数代码文件4、执行结果 一、容器思想 1、自定义类可拷贝 - 深拷贝与浅拷贝 上…

百战python02-语言元素

文章目录 指令与程序变量与类型变量命名变量的使用运算符赋值运算符比较运算符和逻辑运算符练习1:华氏温度转换为摄氏温度练习2:输入圆的半径计算计算周长和面积练习3:输入年份判断是不是闰年字符串常用操作注:需要对python有基本了解,可查看本作者python基础专栏,有任何问…

大模型生态新篇章:以AI Agent为引,助企业创新应用落地

文 | 智能相对论 作者 | 沈浪 以聊天机器人、虚拟助手、智能客服等为代表的对话式人工智能 (Conversational AI Agents ) 在具体服务场景中的应用已经十分普遍。今年以来&#xff0c;随着大模型技术的爆发与加持&#xff0c;对话式AI被市场赋予了更高的期望。 “所有行业都值…

Spring 事务失效的7种场景, 事务失效后如何进行处理

文章目录 简单说说spring事务失效的场景Spring 事务失效的7种场景1.1、未启用[spring事务管理](https://so.csdn.net/so/search?qspring事务管理&spm1001.2101.3001.7020)功能1.2、方法不是public类型的1.3、数据源未配置事务管理器1.4、自身调用问题1.5、异常类型错误1.6…

《golang设计模式》第三部分·行为型模式-07-观察者模式(Observer)/发布者—订阅者模式

文章目录 1. 概念1.1 角色1.2 类图 2. 代码示例2.1 代码2.2 类图 1. 概念 观察者&#xff08;Observer&#xff09;指当目标对象状态发生变化后&#xff0c;对状态变化事件进行响应或处理的对象。 1.1 角色 Subject&#xff08;抽象主题&#xff09;&#xff1a; 它可以有多…

微服务实战系列之Feign

前言 不知不觉&#xff0c;“微服务实战系列”已完成了六篇&#xff0c;每篇都聚焦一个主题&#xff0c;目的是便于各位盆友能够快速、全面地接收和消化。 博主从服务注册到服务监控&#xff0c;从服务路由到服务安全&#xff0c;从身份认证到加密技术均有涉猎。凡此均有关微服…

Java核心知识点整理大全10-笔记

往期快速传送门&#xff1a; Java核心知识点整理大全-笔记_希斯奎的博客-CSDN博客文章浏览阅读9w次&#xff0c;点赞7次&#xff0c;收藏7次。Java核心知识点整理大全https://blog.csdn.net/lzy302810/article/details/132202699?spm1001.2014.3001.5501 Java核心知识点整理…