aiohttp异步请求核心是async/await配合事件循环,单线程复用连接并发处理;需用async with ClientSession()创建会话,await发送请求并读取响应;用asyncio.gather并发执行,配置超时和异常处理,避免新建会话、混用同步代码等陷阱。
使用 aiohttp 实现异步请求,核心是借助 Python 的 async/await 语法配合事件循环,避免阻塞等待网络 I/O。它不是“多线程发请求”,而是单线程内高效复用连接、并发处理多个请求。
必须用 async with aiohttp.ClientSession() 创建会话,不能直接调用 requests.get 那样的同步方式。会话复用连接池,提升性能且自动管理生命周期。
await session.get(url)(或 post、put 等)await resp.text() 或 await resp.json()
await,确保整个函数是 async def,并用 asyncio.run() 启动用 asyncio.gather() 并发执行多个协程,比串行快得多,且无需手动管理线程/进程。
session.get(...) 协程打包传给 gather,它会同时触发并等待全部完成results = await asyncio.gather(req1(), req2(), req3())
gather,可加 return_exceptions=True 捕获异常而非崩溃aiohttp 默认不设超时,生产环境必须显式配置,否则一个卡住的请求可能拖垮整个协程流。
timeout=aiohttp.ClientTimeout(total=10) 控制总耗时try/except 捕获 aiohttp.ClientError 及其子类(如 ClientConnectorError、ServerDisconnectedError)resp.status 或用 raise_for_status()
初学者容易忽略底层约束,导致看似异步实则串行,或资源泄漏。
ClientSession,应复用一个会话实例time.sleep()),改用 await asyncio.sleep()
ClientSession 初始化时传入 headers=... 或 cookies=...
asyncio.Semaphore),防止目标服务拒绝连接