httpx[http2] 和 httpx 的核心区别及使用场景如下
httpx[http2]
和 httpx
的核心区别在于 HTTP/2 协议支持,具体差异及使用场景如下:
1. 功能区别
命令/安装方式 | 协议支持 | 额外依赖 | 适用场景 |
---|---|---|---|
pip install httpx | 仅 HTTP/1.1 | 无 | 通用请求,轻量依赖 |
pip install 'httpx[http2]' | 支持 HTTP/2 | 需安装 h2>=3,<5 等 | 高性能传输、强制HTTP/2的网站 |
- HTTP/1.1:文本格式传输,每个请求独立连接,效率较低。
- HTTP/2:二进制分帧传输,多路复用,头部压缩,性能更高。
2. 使用场景
(1) 基础版 (httpx
)
- 普通API调用:如RESTful接口、爬取大多数网站(非强制HTTP/2)。
- 轻量级需求:无需复杂特性时减少依赖体积。
(2) HTTP/2扩展版 (httpx[http2]
)
- 强制HTTP/2的网站:如某些现代API或反爬严格的站点。
- 高并发请求:利用多路复用降低延迟(如微服务通信)。
- 流式传输:如实时数据推送、大文件下载。
3. 代码示例
启用HTTP/2(需显式声明)
import httpx
import asyncio
# 同步客户端
with httpx.Client(http2=True) as client:response = client.get("https://spa16.scrape.center")print(response.http_version) # 输出 "HTTP/2"# 异步客户端
async def test():async with httpx.AsyncClient(http2=True) as client:res = await client.get("https://spa16.scrape.center")print(res.http_version)print(res.status_code)print(res.text)asyncio.run(test())
注意事项
- 若服务器不支持HTTP/2,会自动降级为HTTP/1.1。
- 需通过
response.http_version
确认实际使用的协议。
4. 扩展功能
httpx[http2]
还可组合其他特性:
# 同时启用HTTP/2和Brotli压缩
pip install 'httpx[http2,brotli]'
总结建议
- 优先选择
httpx[http2]
:现代项目推荐,兼容性更强。 - 仅需HTTP/1.1时:使用基础版以减少依赖。