证明客户端发起HTTP请求后会进入TIME_WAIT状态并占用端口
创始人
2024-04-23 16:07:58
0次
证明客户端发起HTTP请求后会进入TIME_WAIT状态并占用端口
起因
- 线上出现服务器发起Http请求会报 connect: cannot assign requested address 错误的现象
- 原因是HTTP请求四次挥手的发起方会进入TIME_WAIT状态并占用端口,大量的短链接导致端口耗尽
– 在这篇文章里很详细:https://www.cnblogs.com/gaoyanbing/p/16406873.html - 但是眼见为实,于是想测试一下是否真的有TIME_WAIT状态
原理
- Windows电脑下对某个80端口发起请求并通过 netstat -ano |findstr “:80” 查看占用端口的状态
证明过程
1. 查询和80有关的请求,发现并没有东西
2.curl发起一个访问80端口的请求
3.发现一个TIME_WAIT状态的请求,正在占用本地50179端口
4.再发起两个请求
5.发现三个TIME_WAIT的请求分别占用本地的50179,50191,50194端口
6.过一会后占用会自动消失
在代码中测试
1.开协程发起10次访问80端口的请求
- 不开协程而是在一个线程里发起10次请求的话只会产生一个ESTABLISHED状态的请求,可能和复用有关
2.发现8个TIME_WAIT状态的请求和2个ESTABLISHED状态的请求共占用了10个端口
相关内容