TCP三次握手和四次挥手

关于TCP三次握手和四次挥手

image-20210511131244869

  • 一开始,客户端和服务器端都是处于CLOSED关闭状态。先是服务端主动监听某一个端口,并且处于LISTEN状态。

  • 然后客户端主动发起连接SYN,之后处于SYN-SENT状态,发送seq=x,其中x用来表示当前的连接号

  • 服务端收到发起的连接,返回一个SYN没其中seq=y,ack=x+1,表示我已经收到你seq=x的连接了,并发送自己的号。之后便处于接受反馈的状态。

  • 客户端收到SYN包肉,发送ACK码表矫正,seq=x+1表示,这是我编号x的确认吗,用来相应你的编号y的内容。

    到此位置,就建立的连接,三次握手也就完成了。

三次握手趣味版本:

A(客户端):喂,听得到吗?

B(服务器):哎,听得到,你呢?

A(客户端):听得到!

这样就表示你们的联系已经建立,可以正常的开始你们需要的通讯了。

一些问题:

第三次握手是否必要?

答:必要,可以确保客户端和服务端可以建立。否则,以两次握手作为标准,就会出现A收不到信息,但B收的到A的,这样就可以认为是A跟个小傻子一样一直说,但是B不能回应。对于服务器而言,只知道自己的接受没有问题,发送给客户端有没有收到却无从知晓。

小林同学的回答:

如果只有「两次握⼿」,当客户端的 SYN 请求连接在⽹络中阻塞,客户端没有接收到 ACK 报⽂,就会重新发送 SYN ,由于没有第三次握⼿,服务器不清楚客户端是否收到了⾃⼰发送的建⽴连接的ACK 确认信号,所以每收到⼀个 SYN 就只能先主动建⽴⼀个连接,这会造成什么情况呢?如果客户端的 SYN 阻塞了,重复发送多次 SYN 报⽂,那么服务器在收到请求后就会建⽴多个冗余的⽆效链接,造成不必要的资源浪费。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值