证明客户端发起HTTP请求后会进入TIME_WAIT状态并占用端口
创始人
2024-04-23 21:29:05
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个端口

相关内容
不能访问光猫的的管理页面
光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
北信源内网安全管理卸载
北信源内网安全管理是一款网络安全管理软件,主要用于保护内网安全。在日常使用过程中,卸载该软件是一种常...
AWS管理控制台菜单和权限
要在AWS管理控制台中创建菜单和权限,您可以使用AWS Identity and Access Ma...