【浅学Java】三次握手 / 四次挥手

三次握手

1. 三次握手的场景

运用传输层的TCP协议时,在建立连接阶段,就得进行三次握手来完成连接的建立。
在这里插入图片描述

2. 三次握手的目的

2.1 投石问路

通过三次握手可以来确定双方的传输是否通畅。
尤其是确认双方的发送和接收能力是否正常。

在这里插入图片描述

2.2 协调参数

通过三次握手,可以让双方协调选择一些参数,例如:序号是从几开始。

3. 四次握手行不行?

在这里插入图片描述

四次握手理论上是可以的,但是实际上:当A的SYN到达B的时候,B的内核会同时做出ACK和SYN的响应。如果非要分成两步,就会使传输的效率变低

4. 两次握手行不行?

在这里插入图片描述
很显然:两次握手的话,B将无法知道B的发送能力和A的接收能力是否正常。

5. 三次握手时的状态变换

在这里插入图片描述

四次挥手

1. 四次挥手的场景

运用传输层的TCP协议时,在断开连接阶段,就得进行三次握手来完成连接的建立。
在这里插入图片描述

2. 中间的ACK 和 FIN为什么不合并?

在这里插入图片描述

  1. 当B接收到A发送过来得FIN时,内核会立即返回一个ACK,表示收到。
  2. 而B向A发送FIN是由用户代码块控制的,代码中出现socket.close这样的操作时,才会触发FIN。这就可能导致一种特殊情况的发生:B的代码出现问题,导致一直不能close,即一直不能向A发送FIN。

3. 四次挥手时的状态转换

在这里插入图片描述

4. TIME_WAIT如何处理最后一个ACK丢包?

在这里插入图片描述
此时,如果最后一个ACK丢了,此时就无法进行重传了!

设计TIME_WAIT就是为了等待一段时间,以确保最后一个ACK成功发送。

5. 丢包问题

在这里插入图片描述

6. 四次挥手能变成三次吗?

理论上是可以的。

虽然FIN 和 ACK 的触发时机不同,但是在延时应答和捎带应答的情况下,还是可以合并在一起的。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值