证明客户端发起HTTP请求后会进入TIME_WAIT状态并占用端口

证明客户端发起HTTP请求后会进入TIME_WAIT状态并占用端口


起因

  • 线上出现服务器发起Http请求会报 connect: cannot assign requested address 错误的现象
  • 原因是HTTP请求四次挥手的发起方会进入TIME_WAIT状态并占用端口,大量的短链接导致端口耗尽
    – 最终发现是因为线上HBase的客户端发起的请求占光了端口
    – 在这篇文章里很详细: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个端口

在这里插入图片描述

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值