亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Python中異步HTTP客戶端/服務器框架aiohttp的使用全面指南

 更新時間:2025年06月03日 10:11:50   作者:老胖閑聊  
aiohttp 是一個基于 Python asyncio 的異步 HTTP 客戶端/服務器框架,專為高性能網(wǎng)絡編程設計,本文將為大家詳細介紹一下它的具體使用,需要的可以了解下

什么是 aiohttp

aiohttp 是一個基于 Python asyncio 的異步 HTTP 客戶端/服務器框架,專為高性能網(wǎng)絡編程設計。它提供了:

  • 異步 HTTP 客戶端(類似異步版 requests)
  • 異步 HTTP 服務器(類似異步版 Flask/Django)
  • 完整的 WebSocket 支持
  • 高效的連接池管理

核心優(yōu)勢

特性描述
異步非阻塞單線程處理數(shù)千并發(fā)連接
高性能遠超同步框架(如 requests)的吞吐量
輕量級簡潔的API,無復雜依賴
全面協(xié)議支持HTTP/1.1, HTTP/2(客戶端), WebSocket
生態(tài)完善良好文檔和活躍社區(qū)

基礎用法 - HTTP客戶端

安裝

pip install aiohttp

基本GET請求

import aiohttp
import asyncio

async def main():
    async with aiohttp.ClientSession() as session:
        async with session.get('https://api.example.com/data') as response:
            print("狀態(tài)碼:", response.status)
            print("響應內(nèi)容:", await response.text())

asyncio.run(main())

POST請求示例

async def post_example():
    async with aiohttp.ClientSession() as session:
        # 表單數(shù)據(jù)
        async with session.post(
            'https://httpbin.org/post', 
            data={'key': 'value'}
        ) as response:
            print(await response.json())
        
        # JSON數(shù)據(jù)
        async with session.post(
            'https://api.example.com/users',
            json={'name': 'Alice', 'age': 30}
        ) as response:
            print(await response.json())

高級用法

并發(fā)請求

async def fetch(url):
    async with aiohttp.ClientSession() as session:
        async with session.get(url) as response:
            return await response.text()

async def concurrent_requests():
    urls = [
        'https://api.example.com/item/1',
        'https://api.example.com/item/2',
        'https://api.example.com/item/3'
    ]
    
    tasks = [fetch(url) for url in urls]
    results = await asyncio.gather(*tasks)
    
    for url, content in zip(urls, results):
        print(f"{url}: {content[:50]}...")

asyncio.run(concurrent_requests())

超時控制

async def timeout_example():
    timeout = aiohttp.ClientTimeout(total=5)  # 5秒總超時
    
    async with aiohttp.ClientSession(timeout=timeout) as session:
        try:
            async with session.get('https://slow-api.example.com') as response:
                return await response.text()
        except asyncio.TimeoutError:
            print("請求超時!")

流式處理大響應

async def stream_response():
    async with aiohttp.ClientSession() as session:
        async with session.get('https://large-file.example.com') as response:
            with open('large_file.txt', 'wb') as f:
                async for chunk in response.content.iter_chunked(1024):
                    f.write(chunk)
                    print(f"已接收 {len(chunk)} 字節(jié)")

服務器端開發(fā)

基本HTTP服務器

from aiohttp import web

async def handle(request):
    name = request.match_info.get('name', "World")
    return web.Response(text=f"Hello, {name}!")

app = web.Application()
app.add_routes([
    web.get('/', handle),
    web.get('/{name}', handle)
])

if __name__ == '__main__':
    web.run_app(app, port=8080)

REST API示例

async def get_users(request):
    users = [{'id': 1, 'name': 'Alice'}, {'id': 2, 'name': 'Bob'}]
    return web.json_response(users)

async def create_user(request):
    data = await request.json()
    # 實際應用中這里會保存到數(shù)據(jù)庫
    return web.json_response({'id': 3, **data}, status=201)

app = web.Application()
app.add_routes([
    web.get('/api/users', get_users),
    web.post('/api/users', create_user)
])

WebSocket服務器

async def websocket_handler(request):
    ws = web.WebSocketResponse()
    await ws.prepare(request)
    
    async for msg in ws:
        if msg.type == aiohttp.WSMsgType.TEXT:
            if msg.data == 'close':
                await ws.close()
            else:
                await ws.send_str(f"ECHO: {msg.data}")
        elif msg.type == aiohttp.WSMsgType.ERROR:
            print('WebSocket連接異常關(guān)閉')
    
    return ws

???????app.add_routes([web.get('/ws', websocket_handler)])

進階擴展

中間件示例

async def auth_middleware(app, handler):
    async def middleware(request):
        # 驗證API密鑰
        if request.headers.get('X-API-Key') != 'SECRET_KEY':
            return web.json_response({'error': 'Unauthorized'}, status=401)
        return await handler(request)
    return middleware

app = web.Application(middlewares=[auth_middleware])

HTTP/2客戶端支持

async def http2_request():
    conn = aiohttp.TCPConnector(force_close=True, enable_cleanup_closed=True)
    async with aiohttp.ClientSession(connector=conn) as session:
        async with session.get(
            'https://http2.akamai.com/',
            headers={'accept': 'text/html'}
        ) as response:
            print("HTTP版本:", response.version)
            print("內(nèi)容:", await response.text()[:200])

性能優(yōu)化配置

# 自定義連接器配置
connector = aiohttp.TCPConnector(
    limit=100,  # 最大并發(fā)連接數(shù)
    limit_per_host=20,  # 單主機最大連接數(shù)
    ssl=False,  # 禁用SSL驗證(僅用于測試)
    force_close=True  # 避免連接延遲關(guān)閉
)

# 自定義會話配置
session = aiohttp.ClientSession(
    connector=connector,
    timeout=aiohttp.ClientTimeout(total=30),
    headers={'User-Agent': 'MyApp/1.0'},
    cookie_jar=aiohttp.CookieJar(unsafe=True)
)

最佳實踐

重用ClientSession:避免為每個請求創(chuàng)建新會話

使用連接池:合理配置TCPConnector參數(shù)

超時設置:總是配置合理的超時時間

資源清理:使用async with確保資源釋放

錯誤處理:捕獲并處理常見網(wǎng)絡異常

try:
    async with session.get(url) as response:
        response.raise_for_status()
        return await response.json()
except aiohttp.ClientError as e:
    print(f"請求錯誤: {e}")

完整示例

import aiohttp
import asyncio
from aiohttp import web

# 客戶端示例
async def fetch_data():
    async with aiohttp.ClientSession() as session:
        # 并發(fā)請求多個API
        urls = [
            'https://jsonplaceholder.typicode.com/posts/1',
            'https://jsonplaceholder.typicode.com/comments/1',
            'https://jsonplaceholder.typicode.com/albums/1'
        ]
        
        tasks = []
        for url in urls:
            tasks.append(session.get(url))
        
        responses = await asyncio.gather(*tasks)
        
        results = []
        for response in responses:
            results.append(await response.json())
        
        return results

# 服務器示例
async def handle_index(request):
    return web.Response(text="Welcome to aiohttp server!")

async def handle_api(request):
    data = await fetch_data()
    return web.json_response(data)

# 創(chuàng)建應用
app = web.Application()
app.add_routes([
    web.get('/', handle_index),
    web.get('/api', handle_api)
])

# 啟動服務器
async def start_server():
    runner = web.AppRunner(app)
    await runner.setup()
    site = web.TCPSite(runner, 'localhost', 8080)
    await site.start()
    print("Server running at http://localhost:8080")
    
    # 保持運行
    while True:
        await asyncio.sleep(3600)  # 每小時喚醒一次

if __name__ == '__main__':
    asyncio.run(start_server())

總結(jié)

aiohttp 是 Python 異步生態(tài)中處理 HTTP 通信的首選工具,它提供了:

  • 高效客戶端:用于高性能爬蟲、API調(diào)用
  • 輕量級服務器:構(gòu)建高性能Web服務和API
  • WebSocket支持:實現(xiàn)實時雙向通信
  • 連接池管理:優(yōu)化資源利用率

通過合理利用 aiohttp 的異步特性,開發(fā)者可以輕松構(gòu)建出能夠處理數(shù)萬并發(fā)連接的高性能網(wǎng)絡應用,同時保持代碼的簡潔性和可維護性。

到此這篇關(guān)于Python中異步HTTP客戶端/服務器框架aiohttp的使用全面指南的文章就介紹到這了,更多相關(guān)Python異步框架aiohttp內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Python調(diào)用olmOCR大模型實現(xiàn)提取復雜PDF文件內(nèi)容

    Python調(diào)用olmOCR大模型實現(xiàn)提取復雜PDF文件內(nèi)容

    olmocr是由Allen人工智能研究所(AI2)開發(fā)的一個開源工具包,旨在高效地將PDF和其他文檔轉(zhuǎn)換為結(jié)構(gòu)化的純文本,同時保持自然閱讀順序,下面我們來看看如何使用olmOCR大模型實現(xiàn)提取復雜PDF文件內(nèi)容吧
    2025-03-03
  • 處理python中多線程與多進程中的數(shù)據(jù)共享問題

    處理python中多線程與多進程中的數(shù)據(jù)共享問題

    這篇文章主要介紹了python中多線程與多進程中的數(shù)據(jù)共享問題,本文給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-07-07
  • Python 獲取異常(Exception)信息的幾種方法

    Python 獲取異常(Exception)信息的幾種方法

    這篇文章主要介紹了Python 獲取異常(Exception)信息的幾種方法,幫助大家更好的理解和使用python,感興趣的朋友可以了解下
    2020-12-12
  • 使用Python進行批量操作PPT的示例詳解

    使用Python進行批量操作PPT的示例詳解

    將一份PPT的每一頁字體、大小、是否加粗都統(tǒng)一,是一個常見需求,本文將使用Python實現(xiàn)批量操作PPT,感興趣的小伙伴可以跟隨小編一起學習一下
    2025-04-04
  • Python PyQt5實戰(zhàn)項目之文件拷貝器的具體實現(xiàn)詳解

    Python PyQt5實戰(zhàn)項目之文件拷貝器的具體實現(xiàn)詳解

    PyQt5以一套Python模塊的形式來實現(xiàn)功能。它包含了超過620個類,600個方法和函數(shù)。本篇文章手把手帶你用PyQt5實現(xiàn)一個簡單的文件拷貝器,大家可以在過程中查缺補漏,提升水平
    2021-11-11
  • 基于Python自制一個文件解壓縮小工具

    基于Python自制一個文件解壓縮小工具

    經(jīng)常在辦公的過程中會遇到各種各樣的壓縮文件處理,但是呢每個壓縮軟件支持的格式又是不同的。本文就來用Python自制一個文件解壓縮小工具,可以支持7z/zip/rar三種格式,希望對大家有所幫助
    2023-02-02
  • Python3實現(xiàn)騰訊云OCR識別

    Python3實現(xiàn)騰訊云OCR識別

    這篇文章主要為大家詳細介紹了Python3實現(xiàn)騰訊云OCR識別,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-11-11
  • Python中requests庫的概念及使用詳解

    Python中requests庫的概念及使用詳解

    這篇文章主要介紹了Python中requests庫的概念及使用詳解,urllib庫使用繁瑣,比如處理網(wǎng)頁驗證和Cookies時,需要編寫Opener和Handler來處理。為了更加方便的實現(xiàn)這些操作,就有了更為強大的requests庫,需要的朋友可以參考下
    2023-05-05
  • 對python中的高效迭代器函數(shù)詳解

    對python中的高效迭代器函數(shù)詳解

    今天小編就為大家分享一篇對python中的高效迭代器函數(shù)詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-10-10
  • PyTorch 如何設置隨機數(shù)種子使結(jié)果可復現(xiàn)

    PyTorch 如何設置隨機數(shù)種子使結(jié)果可復現(xiàn)

    這篇文章主要介紹了PyTorch 設置隨機數(shù)種子使結(jié)果可復現(xiàn)操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-05-05

最新評論