当前位置: 首页 > article >正文

Python 异步HTTP客户端实战:aiohttp深度解析

Python 异步HTTP客户端实战aiohttp深度解析引言在现代Python后端开发中异步HTTP客户端是构建高性能服务的关键组件。作为一名从Rust转向Python的后端开发者我深刻体会到异步编程在处理大量并发请求时的优势。aiohttp作为Python生态中最流行的异步HTTP客户端库提供了强大的功能和良好的性能。异步HTTP客户端核心概念什么是异步HTTP客户端异步HTTP客户端允许在等待服务器响应时执行其他任务具有以下特点非阻塞IO请求发送后立即返回不阻塞主线程高并发可以同时处理大量HTTP请求资源高效减少线程创建和上下文切换开销响应式编程支持回调和协程两种模式架构设计┌─────────────────────────────────────────────────────────────┐ │ 异步HTTP客户端 │ │ ┌─────────────────────────────────────────────────────┐ │ │ │ 协程调度器 → 请求发送 → IO等待 → 响应处理 │ │ │ └─────────────────────────┬─────────────────────────┘ │ └─────────────────────────────┼─────────────────────────────┘ │ TCP连接 ▼ ┌─────────────────────────────────────────────────────────────┐ │ HTTP 服务器 │ │ ┌─────────────────────────────────────────────────────┐ │ │ │ 接收请求 → 处理请求 → 返回响应 │ │ │ └─────────────────────────────────────────────────────┘ │ └─────────────────────────────────────────────────────────────┘环境搭建与基础配置安装依赖pip install aiohttp requests基本异步HTTP请求import asyncio import aiohttp async def fetch(session, url): async with session.get(url) as response: return await response.text() async def main(): async with aiohttp.ClientSession() as session: html await fetch(session, https://api.example.com/data) print(html) asyncio.run(main())并发请求async def fetch_all(urls): async with aiohttp.ClientSession() as session: tasks [fetch(session, url) for url in urls] results await asyncio.gather(*tasks) return results async def main(): urls [ https://api.example.com/1, https://api.example.com/2, https://api.example.com/3 ] results await fetch_all(urls) for result in results: print(result) asyncio.run(main())请求配置与参数请求头配置async def fetch_with_headers(session, url): headers { User-Agent: Mozilla/5.0, Authorization: Bearer token123, Content-Type: application/json } async with session.get(url, headersheaders) as response: return await response.json()查询参数async def fetch_with_params(session, url, params): async with session.get(url, paramsparams) as response: return await response.json() async def main(): params {q: python, limit: 10, page: 1} async with aiohttp.ClientSession() as session: result await fetch_with_params(session, https://api.example.com/search, params) print(result) asyncio.run(main())POST请求async def post_data(session, url, data): async with session.post(url, jsondata) as response: return await response.json() async def main(): data {name: 张三, email: zhangsanexample.com} async with aiohttp.ClientSession() as session: result await post_data(session, https://api.example.com/users, data) print(result) asyncio.run(main())高级特性实战超时设置async def fetch_with_timeout(session, url): timeout aiohttp.ClientTimeout(total10) try: async with session.get(url, timeouttimeout) as response: return await response.text() except asyncio.TimeoutError: print(请求超时) return None连接池配置async def create_custom_session(): timeout aiohttp.ClientTimeout(total30) connector aiohttp.TCPConnector( limit100, limit_per_host10, keepalive_timeout30 ) async with aiohttp.ClientSession( timeouttimeout, connectorconnector ) as session: async with session.get(https://api.example.com) as response: return await response.text()文件上传async def upload_file(session, url, file_path): form aiohttp.FormData() form.add_field(file, open(file_path, rb)) async with session.post(url, dataform) as response: return await response.json() async def main(): async with aiohttp.ClientSession() as session: result await upload_file(session, https://api.example.com/upload, test.txt) print(result) asyncio.run(main())实际业务场景场景一API批量请求async def fetch_api_data(session, endpoint): url fhttps://api.example.com{endpoint} try: async with session.get(url) as response: if response.status 200: return await response.json() else: print(f请求失败 {url}: {response.status}) return None except Exception as e: print(f请求异常 {url}: {e}) return None async def batch_fetch(): endpoints [ /users, /posts, /comments, /products, /orders ] async with aiohttp.ClientSession() as session: tasks [fetch_api_data(session, endpoint) for endpoint in endpoints] results await asyncio.gather(*tasks) return dict(zip(endpoints, results)) asyncio.run(batch_fetch())场景二数据爬虫async def scrape_page(session, url): async with session.get(url) as response: if response.status 200: html await response.text() # 解析HTML提取数据 data parse_html(html) return data return None async def scrape_all_pages(base_url, pages): async with aiohttp.ClientSession() as session: tasks [] for page in range(1, pages 1): url f{base_url}?page{page} tasks.append(scrape_page(session, url)) results await asyncio.gather(*tasks) return [r for r in results if r]场景三微服务调用class APIClient: def __init__(self, base_url): self.base_url base_url self.session None async def __aenter__(self): self.session aiohttp.ClientSession() return self async def __aexit__(self, exc_type, exc_val, exc_tb): await self.session.close() async def get_user(self, user_id): url f{self.base_url}/users/{user_id} async with self.session.get(url) as response: return await response.json() async def create_order(self, order_data): url f{self.base_url}/orders async with self.session.post(url, jsonorder_data) as response: return await response.json() async def main(): async with APIClient(https://api.example.com) as client: user await client.get_user(123) order await client.create_order({user_id: 123, items: []}) print(user, order) asyncio.run(main())性能优化并发控制async def fetch_with_semaphore(session, semaphore, url): async with semaphore: async with session.get(url) as response: return await response.text() async def controlled_fetch(urls, max_concurrent10): semaphore asyncio.Semaphore(max_concurrent) async with aiohttp.ClientSession() as session: tasks [fetch_with_semaphore(session, semaphore, url) for url in urls] results await asyncio.gather(*tasks) return results请求重试from tenacity import retry, stop_after_attempt, wait_exponential retry(stopstop_after_attempt(3), waitwait_exponential(multiplier1, min2, max10)) async def fetch_with_retry(session, url): async with session.get(url) as response: if response.status 500: raise Exception(fServer error: {response.status}) return await response.json()响应缓存from functools import lru_cache class CachedAPIClient: def __init__(self): self.session None async def __aenter__(self): self.session aiohttp.ClientSession() return self async def __aexit__(self, exc_type, exc_val, exc_tb): await self.session.close() lru_cache(maxsize128) async def get_data(self, url): async with self.session.get(url) as response: return await response.json()总结aiohttp为Python后端开发者提供了强大的异步HTTP客户端能力。通过非阻塞IO和协程机制aiohttp能够高效处理大量并发请求。从Rust开发者的角度来看aiohttp的设计思想与Rust的异步运行时相似都强调高效的资源利用和并发处理。在实际项目中建议合理配置连接池、设置超时时间并使用并发控制来避免对目标服务器造成压力。

相关文章:

Python 异步HTTP客户端实战:aiohttp深度解析

Python 异步HTTP客户端实战:aiohttp深度解析 引言 在现代Python后端开发中,异步HTTP客户端是构建高性能服务的关键组件。作为一名从Rust转向Python的后端开发者,我深刻体会到异步编程在处理大量并发请求时的优势。aiohttp作为Python生态中最流…...

Fujirebio宣布全自动Lumipulse® G pTau 217血浆检测试剂盒获得CE认证

H.U. Group Holdings Inc.及其全资子公司Fujirebio今日宣布,Fujirebio Europe N.V.已依据《欧盟(EU) 2017/746体外诊断医疗器械法规》(IVDR)取得Lumipulse G pTau 217血浆检测试剂盒的CE认证。该化学发光酶免疫分析(CLEIA)检测可对人体血浆(K2 EDTA)中的苏氨酸217磷…...

5分钟免费解锁Cursor Pro:终极AI编程助手无限使用方案

5分钟免费解锁Cursor Pro:终极AI编程助手无限使用方案 【免费下载链接】cursor-free-vip [Support 0.45](Multi Language 多语言)自动注册 Cursor Ai ,自动重置机器ID , 免费升级使用Pro 功能: Youve reached your tri…...

QT实战:利用QAxObject与QAxWidget实现Office文档自动化,从数据填充到格式定制

1. 为什么需要Office文档自动化? 在企业日常运营中,文档处理是绕不开的环节。我见过太多同事每天花几个小时手动复制粘贴数据到Word报告和Excel表格里,不仅效率低下,还容易出错。想象一下,财务部门每月要生成上百份报…...

告别天书:用Python+NumPy手把手实现Turbo码的迭代译码(附完整代码)

告别天书:用PythonNumPy手把手实现Turbo码的迭代译码(附完整代码) 在通信系统的演进历程中,Turbo码的出现犹如一场静默的革命。1993年,当Berrou等人首次公开这项技术时,其接近香农极限的性能让整个学术界为…...

NotebookLM如何重构你的NLP工作流,72小时实现从零标注到可部署模型闭环

更多请点击: https://intelliparadigm.com 第一章:NotebookLM如何重构你的NLP工作流,72小时实现从零标注到可部署模型闭环 NotebookLM 是 Google 推出的实验性 AI 助手,专为结构化文档理解与知识驱动建模而设计。它并非传统 LLM …...

告别照片管理烦恼:ExifToolGUI帮你3步搞定批量元数据处理

告别照片管理烦恼:ExifToolGUI帮你3步搞定批量元数据处理 【免费下载链接】ExifToolGui A GUI for ExifTool 项目地址: https://gitcode.com/gh_mirrors/ex/ExifToolGui 你是否曾为数百张旅行照片的整理而头疼?拍摄时间需要统一调整,版…...

NotebookLM笔记生产力跃迁(仅限前500名早鸟用户的动态模板库已开放)

更多请点击: https://intelliparadigm.com 第一章:NotebookLM笔记生产力跃迁(仅限前500名早鸟用户的动态模板库已开放) NotebookLM 正式引入基于语义理解的「上下文感知模板引擎」,早鸟用户可通过专属入口启用动态模板…...

别再死磕ViT了!用Swin-Transformer搞定高分辨率图像识别,保姆级原理拆解

高分辨率图像识别新范式:Swin-Transformer实战指南 当计算机视觉工程师面对4K医学影像或卫星地图时,传统ViT模型往往会遭遇显存爆炸的尴尬。我曾在一个遥感项目中发现,直接将ViT应用于20482048像素的图像,单次前向传播就消耗了32G…...

构建可靠AI智能体:从提示词工程到结构化内容生成的实战指南

1. 项目概述与核心思路最近在折腾AI应用开发,特别是想搞一个能稳定输出、逻辑清晰、还能带点“人味儿”的文本生成工具。市面上现成的方案要么太“机械”,要么定制化程度不够,总感觉差点意思。后来,我在一个开发者社区里看到了一个…...

人工智能-现代方法(一)

2026.05.12 这几天开始看《人工智能-现代方法》,做一些知识记录。 1、学习的概念:归纳和演绎。(19章) 演绎靠逻辑推理,归纳靠经验总结。所以在前提正确的情况下,演绎的结论必然正确。归纳的结论则有可能出现…...

OBS Source Record插件完全掌握指南:实现多源独立录制的终极解决方案

OBS Source Record插件完全掌握指南:实现多源独立录制的终极解决方案 【免费下载链接】obs-source-record 项目地址: https://gitcode.com/gh_mirrors/ob/obs-source-record 你是否曾经在直播或录制视频时,想要单独保存某个特定的画面源&#xf…...

【Claude API集成实战指南】:20年专家亲授FastAPI高效对接Claude的7大避坑法则

更多请点击: https://intelliparadigm.com 第一章:Claude API集成的核心原理与FastAPI技术选型 Claude API 采用基于 HTTP/2 的流式 REST 接口设计,核心通信模式为双向流(/v1/messages 端点),支持 event:…...

STM32F103C6/RC + HC-SR04超声波测距:Proteus 8.9仿真避坑与LCD1602显示实战

STM32F103C6/RC HC-SR04超声波测距:Proteus 8.9仿真避坑与LCD1602显示实战 在嵌入式开发的学习过程中,仿真工具为我们提供了极大的便利,尤其是对于资源有限或硬件条件不足的开发者来说,Proteus仿真软件无疑是一把利器。然而&…...

自动化测试(十) 微服务测试策略-单元到集成到契约到端到端分层实战

微服务测试策略:单元→集成→契约→端到端分层实战前面咱们分别聊了单元测试、接口测试、契约测试。今天把它们串起来,聊聊微服务架构下怎么设计完整的测试策略——每一层测什么、怎么测、用什么工具。一、微服务测试的"金字塔"变体 单体应用的…...

蓝牙窃密攻防实战:从协议漏洞到固件后门,国家安全部警示的近场威胁全解析

2026年5月11日,国家安全部官方发布重磅警示,明确指出蓝牙设备已成为不法分子实施近距离窃密、监听、跟踪的"隐形獠牙"。从日常使用的无线耳机、智能手表,到办公场景的蓝牙键鼠、会议音箱,再到工业控制中的蓝牙传感器&am…...

芯片设计公司ISO 9001认证:从质量管理体系到流片成功的工程实践

1. 从一则旧闻聊起:ISO 9001认证对一家芯片设计公司意味着什么?前几天在整理资料时,偶然翻到一篇2011年的行业旧闻,说的是当时一家名为SiliconBlue Technologies的公司,获得了ISO 9001:2008质量管理体系认证。新闻稿写…...

音频算法调试利器:用Android App实时绘制EQ/DRC曲线,告别Matlab依赖

移动端音频算法调试革命:Android实时EQ/DRC可视化工具开发实战 在音频算法开发领域,调试环节长期被桌面级工具垄断,工程师们不得不忍受开发板与工作站之间的频繁切换。这种工作模式不仅效率低下,更无法满足现代音频产品快速迭代的…...

AntiDupl.NET:告别数字杂乱,让图片管理回归优雅

AntiDupl.NET:告别数字杂乱,让图片管理回归优雅 【免费下载链接】AntiDupl A program to search similar and defect pictures on the disk 项目地址: https://gitcode.com/gh_mirrors/an/AntiDupl 你是否曾经在整理照片时,发现手机里…...

基于本地大模型与Playwright的隐私优先求职自动化助手RedClaw实践

1. 项目概述:一个真正为你掌控的本地化求职AI助手在求职季,我们常常面临一个两难困境:一方面,海投简历耗时耗力,重复填写那些大同小异的在线申请表让人筋疲力尽;另一方面,市面上一些所谓的“自动…...

苹果为何拒绝TD-SCDMA特供版iPhone?复盘技术标准与市场时机的战略博弈

1. 项目概述:一场关于苹果与中国移动的世纪猜想2012年的科技圈,空气中弥漫着一股躁动与期待。几乎所有的行业分析师和手机发烧友都在讨论同一个话题:苹果公司是否会为了全球最大的移动运营商——中国移动,专门推出一款支持TD-SCDM…...

机器视觉在人工智能领域的应用

机器视觉在人工智能领域的应用 目录机器视觉在人工智能领域的应用一、图像处理与机器视觉的概念阐述1. 图像处理(Image Processing)2. 机器视觉(Machine Vision / Computer Vision)二、图像处理与机器视觉的区别与共同点区别共同点…...

如何通过Python快速接入Taotoken并调用多模型API完成文本生成任务

🚀 告别海外账号与网络限制!稳定直连全球优质大模型,限时半价接入中。 👉 点击领取海量免费额度 如何通过Python快速接入Taotoken并调用多模型API完成文本生成任务 1. 准备工作:获取API Key与模型ID 在开始编写代码之…...

嵌入式开发中的编程规范实践与行业标准解析

1. 编程规范的本质与价值在嵌入式汽车电子领域干了十五年,我见过太多因为代码不规范导致的惨痛教训。有一次,某车企的ECU控制模块在零下30度环境突然死机,排查三周后发现是未初始化的指针在低温环境下产生了非预期行为——这种问题本可以通过…...

实战复盘:我是如何通过一个SSRF漏洞,利用Gopher协议拿下内网Redis的

从SSRF到内网Redis入侵:一次真实渗透测试的深度剖析 那天下午,我正在对某企业Web应用进行常规安全评估。一个看似普通的文件下载接口引起了我的注意——它接受URL参数并返回对应资源内容。直觉告诉我,这里可能存在SSRF漏洞。接下来的72小时&a…...

一句话就能“劫持”你的AI?DZS 分层式自适应提示词注入攻击的防御机制框架 (HAA)来了!

本文所展示的提示词技术已在Research square 发表论文预印本。DOI:https://doi.org/10.21203/rs.3.rs-9653510/v1 作者“抖知书(douzhishu),涉及到相关测试数据是本人自行测试的,并未通过多专家评审,所以仅…...

新手避坑指南:用Simulink搭建48V开关电源仿真,从整流到反激电路完整流程

新手避坑指南:用Simulink搭建48V开关电源仿真全流程实战 电力电子领域的仿真实验常常让初学者望而生畏——参数设置不当可能导致虚拟元器件"烧毁",波形失真却找不到原因。本文将手把手带你用Simulink搭建从交流整流到DC-DC变换的完整48V电源系…...

PX4倾转垂起固定翼混控配置与硬件适配实战

1. PX4倾转垂起固定翼的核心概念解析 第一次接触倾转垂起固定翼的朋友可能会被这个名词吓到,其实它的原理并不复杂。简单来说,这是一种既能像多旋翼一样垂直起降,又能像固定翼飞机一样高效巡航的混合飞行器。我经手过的项目中,这种…...

告别公网IP焦虑:用SakuraFrp免费隧道,5分钟搞定Linux服务器的SSH远程访问

5分钟实现无公网IP的Linux服务器远程访问:SakuraFrp实战指南 当你需要在外紧急处理家中或办公室的Linux服务器时,却发现没有公网IP无法远程连接,这种焦虑我深有体会。去年深夜的一次线上故障让我深刻认识到内网穿透工具的重要性——当时我正…...

SBQE:量子机器学习数据编码的创新方法

1. SBQE:量子机器学习数据编码的新范式量子计算领域最近迎来了一项突破性进展——SBQE(Shot-Based Quantum Encoding)数据编码方法。作为一名长期跟踪量子机器学习发展的研究者,我亲历了这项技术从理论提出到实验验证的全过程。SB…...