HTTP的三次握手以及四次挥手

一、三次握手

本质是客户端与浏览器总共发送了3个包,目的就是为了确认双方的接受和发送能力是否正常,为之后建立TCP链接做准备

(1)客户端向服务端发送一个SYN报文(一个数据包),来请求链接

(2)服务端接受到SYN报文,并发送自己的ACK报文,表示自己接受到了客户端的SYN,然后把自己的SYN报文发出作为应答发送给客户端

(3) 客户端接受到了SYN报文,再发送ACK报文,给予确认,双方已经建立起链接

 

扩展问题:

1、为什么是3次握手,而不是2次?

因为三次握手的目的是为了确认双方的接受和发送能力是否正常,为之后建立TCP链接做准备

(1)先来看第一次,是客户端发送网络包,服务端接受到了,这样得出结论:客户端的发送能力正常,服务端的接受能力正常

(2)第二次握手,表示服务端发包,客户端接受到了,得出结论:服务端的接受、发送能力正常客户端的接受能力正常,但是此时服务器还不知道客户端的接受能力是否正常

(3)客户端发包,服务端收到了,得出结论:服务端知道了客户端的接受能力正常

2、三次握手可以携带数据吗?

第一、二次不可以,因为如果第一次可以携带数据的话,会有人在此环节,发送大量的数据,造成客户端疯狂向服务端发送SYN报文,这会让服务端花费很长时间及内存空间来接受这些报文。

但是对于第三次握手,前两次握手已经建立起了链接,这时候发送数据也没毛病

二、四次挥手

由于TCP提供了链接一段在结束自己的发送后还能接受来自另一端的数据的能力,被称为TCP的半关闭

(1) 客户端发送一个fin报文,停止发送数据,准备关闭TCP链接,等待服务端确认

(2) 服务端接受到fin,并且会发送自己的ack报文,表示已经收到报文了,此时客服端TCP处于半关闭状态,结束了自己的发送,但能接受数据

(3)等待服务端处理好所有报文之后,客户端想要断开链接,发送链接释放报文,等待客户端的确认 

(4) 客户端接受到,发送fin报文,确定关闭链接'

问题:挥手为什么四次

因为服务端收到客户端的fin报文后,可直接发送fin+ack报文,表示收到了报文,但是服不会立即关闭链接,等到所有报文都发送完,再发fin报文,因此不能一起发送,才需要四次

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
HTTP三次握手四次挥手是TCP协议在建立连接和断开连接时的过程。为了确保双方的接收能力和发送能力都正常,需要进行三次握手。两次握手是不够的,因为在两次握手的情况下,如果客户端发送的连接请求在网络中滞留,那么服务器会误以为客户端已经关闭连接,从而导致服务器资源的浪费。而通过三次握手,可以确保双方都能够正常地发送和接收数据。 三次握手的过程如下[^1]: 1. 客户端向服务器发送一个连接请求报文段,该报文段中包含了客户端的初始序列号(SYN)。 2. 服务器收到请求后,向客户端发送一个确认报文段,该报文段中包含了服务器的初始序列号(SYN)和确认序号(ACK)。 3. 客户端收到确认报文段后,再向服务器发送一个确认报文段,该报文段中包含了客户端的确认序号(ACK)。 四次挥手的过程如下[^2]: 1. 客户端向服务器发送一个连接释放请求报文段,该报文段中包含了客户端的序列号(FIN)。 2. 服务器收到请求后,向客户端发送一个确认报文段,该报文段中包含了服务器的确认序号(ACK)。 3. 服务器向客户端发送一个连接释放请求报文段,该报文段中包含了服务器的序列号(FIN)。 4. 客户端收到请求后,向服务器发送一个确认报文段,该报文段中包含了客户端的确认序号(ACK)。 通过三次握手四次挥手,可以确保双方在建立和断开连接时的可靠性和稳定性。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值