ConnectionError通常因网络连接问题、目标服务器不可达、防火墙或代理限制、DNS解析失败、请求超时、ssl/TLS证书问题及并发过多导致,需逐步排查网络通路并配置合理重试与超时机制。

python中出现ConnectionError通常表示程序在尝试与远程服务器建立网络连接时失败。这个异常属于requests库(基于urllib3)抛出的连接类错误,常见于使用requests.get()、requests.post()等方法时。下面分析其常见原因及对应的解决方法。
1. 网络连接问题
最基础的原因是本地设备没有正常联网,或目标服务器无法访问。
2. 目标服务器不可达或宕机
远程服务关闭、IP变更、域名解析失败都会导致连接错误。
3. 防火墙或代理限制
企业网络或云服务器常配置防火墙规则,阻止外部请求。
立即学习“Python免费学习笔记(深入)”;
- 确认是否需要配置代理才能访问外网。
可设置requests的proxies参数:
proxies = {
‘http’: ‘http://proxy.company.com:8080’,
‘https’: ‘https://proxy.company.com:8080’
}
requests.get(url, proxies=proxies)
- 检查本地防火墙或杀毒软件是否拦截了Python进程。
4. DNS解析失败
域名无法解析为IP地址,也会引发连接异常。
- 尝试更换DNS服务器,如使用google DNS(8.8.8.8)。
- 在代码中直接使用IP地址测试(注意HTTPS证书可能不匹配)。
- 检查
/etc/hosts(linux/Mac)或C:windowsSystem32driversetchosts(Windows)是否有错误映射。
5. 请求超时未及时断开
连接长时间挂起后被中断,可能包装为ConnectionError。
- 设置合理的超时时间避免无限等待:
try:
response = requests.get(url, timeout=10)
except requests.exceptions.ConnectionError:
print(“连接失败,请检查网络”)
6. SSL/TLS证书问题(HTTPS)
证书过期、自签名或不受信任可能导致底层连接中断。
- 临时测试可禁用SSL验证(不推荐生产环境):
requests.get(url, verify=False)
- 更安全的方式是将证书添加到可信列表,并通过
verify='/path/to/cert.pem'指定路径。
7. 并发过多被服务器拒绝
短时间内发起大量请求,可能被对方限流或封IP。
- 加入延迟控制,如
time.sleep(1)。 - 使用会话(session)复用连接,减少频繁握手。
- 考虑使用重试机制配合指数退避:
from requests.adapters import HTTPAdapter
from urllib3.util.retry import Retry
session = requests.Session()
retries = Retry(total=3, backoff_factor=1)
session.mount(‘http://’, HTTPAdapter(max_retries=retries))
session.mount(‘https://’, HTTPAdapter(max_retries=retries))
基本上就这些。遇到ConnectionError先从网络通路查起,逐步排除本地、中间链路和目标服务的问题。加上适当的异常处理和日志输出,能更快定位根源。