0

0

Python 请求超时不是越大越安全

舞姬之光

舞姬之光

发布时间:2026-02-19 16:54:57

|

511人浏览过

|

来源于php中文网

原创

requests.get()必须显式设置timeout,推荐拆分为连接超时和读取超时(如(3,10)),并配合retry机制处理临时错误,同时注意系统级tcp参数对实际超时的影响。

python 请求超时不是越大越安全

requests.get() 的 timeout 参数到底该设多少

超时不是保险丝,设太大反而会让程序卡死更久。默认不设 timeout 就是无限等待,遇到网络挂起或服务无响应,整个线程就僵在那儿了。

实操建议:必须显式传入 timeout,且拆成连接超时和读取超时两部分:

  • timeout=(3, 10) 表示连接最多等 3 秒,连上后读响应最多等 10 秒
  • 纯数字如 timeout=10 是历史兼容写法,等价于 (10, 10),但掩盖了连接/读取阶段的差异
  • 连接超时(第一个数)通常 2–5 秒足够;读取超时(第二个数)取决于接口实际响应时间,建议比 P95 响应时间高 20%~50%

requests 超时后不会自动重试,得自己兜底

很多人以为设了 timeout 就等于“失败自动再试一次”,其实不是。requests.get() 超时抛出的是 requests.exceptions.Timeout,它不重试,也不触发重定向逻辑。

常见错误现象:请求偶尔超时,日志里只看到一次失败,但业务上需要更高可用性。

立即学习Python免费学习笔记(深入)”;

实操建议:用 urllib3.util.retry.Retry 配合 requests.adapters.HTTPAdapter 控制重试行为:

  • 别直接用 try/except 包一层就循环重试——可能把幂等性搞砸(比如重复扣款)
  • 对 GET 请求可开重试,POST/PUT 建议谨慎;重试次数建议 ≤3,间隔用指数退避(backoff_factor=0.3
  • 务必排除 status_forcelist=(429, 502, 503, 504) 等临时错误码,别把 400 错误也重试

异步场景下 aiohttp 的 timeout 更容易被忽略

aiohttp.ClientSession 时,timeout 不是传给 get() 的参数,而是要提前配在 session 或 request 级别,漏掉就退化成无限等待。

橙篇
橙篇

百度文库发布的一款综合性AI创作工具

下载

使用场景:爬虫、网关聚合、定时同步任务——这些地方一旦某个请求卡住,整个协程池可能被拖慢。

实操建议:

  • 创建 session 时用 aiohttp.ClientTimeout(total=30, connect=5, sock_read=10) 显式控制各阶段
  • 单次请求可覆盖: session.get(url, timeout=aiohttp.ClientTimeout(sock_read=8))
  • 注意 total 是总时限,会覆盖其他单项;若设了 total=5 又设 connect=10,实际仍按 5 秒截断

超时值受系统级 socket 设置影响

Python 层设了 timeout=3,但底层 TCP 握手可能被操作系统拖得更久——比如 Linux 的 tcp_syn_retries 默认重试 6 次,每次间隔翻倍,加起来能到 20 多秒。

性能影响:线上服务若大量出现“明明设了 3 秒超时,却卡了 20 秒才报错”,大概率是这个原因。

实操建议:

  • 检查 /proc/sys/net/ipv4/tcp_syn_retries,生产环境建议调成 3(对应约 3 秒)
  • Docker 容器内需在启动时用 --sysctl 注入,或在 entrypoint 里 echo 修改
  • 云函数(如 AWS Lambda)无法改内核参数,那就只能靠更保守的 Python 层 timeout + 主动 cancel task

超时不是填个数字就完事,它是连接层、协议层、应用层三者共同作用的结果。最容易被忽略的是:你设的那个数字,未必真能生效。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
session失效的原因
session失效的原因

session失效的原因有会话超时、会话数量限制、会话完整性检查、服务器重启、浏览器或设备问题等等。详细介绍:1、会话超时:服务器为Session设置了一个默认的超时时间,当用户在一段时间内没有与服务器交互时,Session将自动失效;2、会话数量限制:服务器为每个用户的Session数量设置了一个限制,当用户创建的Session数量超过这个限制时,最新的会覆盖最早的等等。

327

2023.10.17

session失效解决方法
session失效解决方法

session失效通常是由于 session 的生存时间过期或者服务器关闭导致的。其解决办法:1、延长session的生存时间;2、使用持久化存储;3、使用cookie;4、异步更新session;5、使用会话管理中间件。

773

2023.10.18

cookie与session的区别
cookie与session的区别

本专题整合了cookie与session的区别和使用方法等相关内容,阅读专题下面的文章了解更详细的内容。

97

2025.08.19

lambda表达式
lambda表达式

Lambda表达式是一种匿名函数的简洁表示方式,它可以在需要函数作为参数的地方使用,并提供了一种更简洁、更灵活的编码方式,其语法为“lambda 参数列表: 表达式”,参数列表是函数的参数,可以包含一个或多个参数,用逗号分隔,表达式是函数的执行体,用于定义函数的具体操作。本专题为大家提供lambda表达式相关的文章、下载、课程内容,供大家免费下载体验。

212

2023.09.15

python lambda函数
python lambda函数

本专题整合了python lambda函数用法详解,阅读专题下面的文章了解更多详细内容。

192

2025.11.08

Python lambda详解
Python lambda详解

本专题整合了Python lambda函数相关教程,阅读下面的文章了解更多详细内容。

58

2026.01.05

硬盘接口类型介绍
硬盘接口类型介绍

硬盘接口类型有IDE、SATA、SCSI、Fibre Channel、USB、eSATA、mSATA、PCIe等等。详细介绍:1、IDE接口是一种并行接口,主要用于连接硬盘和光驱等设备,它主要有两种类型:ATA和ATAPI,IDE接口已经逐渐被SATA接口;2、SATA接口是一种串行接口,相较于IDE接口,它具有更高的传输速度、更低的功耗和更小的体积;3、SCSI接口等等。

1529

2023.10.19

PHP接口编写教程
PHP接口编写教程

本专题整合了PHP接口编写教程,阅读专题下面的文章了解更多详细内容。

423

2025.10.17

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

660

2026.02.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 22.4万人学习

Django 教程
Django 教程

共28课时 | 4.4万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.6万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号