三次握手和四次握手到底有啥区别?

简介: 三次握手和四次握手到底有啥区别?

1. 三次握手

TCP 协议中,在发送数据的准备阶段,客户端与服务器之间的三次交互,以保 证连接的可靠。

  1. • 第一次握手,客户端向服务器端发起 TCP 连接的请求
  2. • 第二次握手,服务器端发送针对客户端 TCP 连接请求的确认
  3. • 第三次握手,客户端发送确认的确认

三次握手和四次握手描述(来自尚硅谷)

1、客户端会随机一个初始序列号 seq=x,设置 SYN=1 ,表示这是 SYN 握手报文。然后就可以把这个 SYN 报文发送给服务端了,表示 向服务端发起连接,之后客户端处于同步已发送状态。 2、服务端收到客户端的 SYN 报文后,也随机一个初始序列号 (seq=y),设置 ack=x+1,表示收到了客户端的 x 之前的数据,希望客 户端下次发送的数据从 x+1 开始。 设置 SYN=1 和 ACK=1。表示这 是一个 SYN 握手和 ACK 确认应答报文。最后把该报文发给客户端,该 报文也不包含应用层数据,之后服务端处于同步已接收状态。

3、客户端收到服务端报文后,还要向服务端回应最后一个应答报文, 将 ACK 置为 1 ,表示这是一个应答报文 ack=y+1 ,表示收到了服务 器的 y 之前的数据,希望服务器下次发送的数据从 y+1 开始。 最后 把报文发送给服务端,这次报文可以携带数据,之后客户端处于 连接 已建立 状态。服务器收到客户端的应答报文后,也进入连接已建立状 态。

       完成三次握手,连接建立后,客户端和服务器就可以开始进行数据传输了。由 于这种面向连接的特性,TCP 协议可以保证传输数据的安全,所以应用十分广 泛,例如下载文件、浏览网页等。

2 四次挥手

TCP 协议中,在发送数据结束后,释放连接时需要经过四次挥手。

  1. • 第一次挥手:客户端向服务器端提出结束连接,让服务器做最后的准备工作。此 时,客户端处于半关闭状态,即表示不再向服务器发送数据了,但是还可以接受数 据。
  2. • 第二次挥手:服务器接收到客户端释放连接的请求后,会将最后的数据发给客户 端。并告知上层的应用进程不再接收数据。
  3. • 第三次挥手:服务器发送完数据后,会给客户端发送一个释放连接的报文。那么客 户端接收后就知道可以正式释放连接了。
  4. • 第四次挥手:客户端接收到服务器最后的释放连接报文后,要回复一个彻底断开的 报文。这样服务器收到后才会彻底释放连接。这里客户端,发送完最后的报文后,会 等待 2MSL,因为有可能服务器没有收到最后的报文,那么服务器迟迟没收到,就会 再次给客户端发送释放连接的报文,此时客户端在等待时间范围内接收到,会重新发 送最后的报文,并重新计时。如果等待 2MSL 后,没有收到,那么彻底断开。

1、客户端打算断开连接,向服务器发送 FIN 报文(FIN 标记位被设置为 1,1 表示为 FIN,0 表示不是),FIN 报文中会指定一个序列号,之后 客户端进入 FINWAIT1 状态。也就是客户端发出连接释放报文段(FIN 报文),指定序列号 seq = u,主动关闭 TCP 连接,等待服务器的确 认。

2、服务器收到连接释放报文段(FIN 报文)后,就向客户端发送 ACK 应 答报文,以客户端的 FIN 报文的序列号 seq+1 作为 ACK 应答报文段 的确认序列号 ack = seq+1 = u + 1。接着服务器进入 CLOSEWAIT(等 待关闭)状态,此时的 TCP 处于半关闭状态(下面会说什么是半关闭状 态),客户端到服务器的连接释放。客户端收到来自服务器的 ACK 应答 报文段后,进入 FINWAIT_2 状态。

3、服务器也打算断开连接,向客户端发送连接释放(FIN)报文段,之后 服务器进入 LASK_ACK(最后确认)状态,等待客户端的确认。服务器的 连接释放(FIN)报文段的 FIN=1,ACK=1,序列号 seq=m,确认序列号 ack=u+1。

4、客户端收到来自服务器的连接释放(FIN)报文段后,会向服务器发送 一个 ACK 应答报文段,以连接释放(FIN)报文段的确认序号 ack 作为 ACK 应答报文段的序列号 seq,以连接释放(FIN)报文段的序列号 seq+1 作为确认序号 ack。

之后客户端进入 TIMEWAIT(时间等待)状态,服务器收到 ACK 应答报文 段后,服务器就进入 CLOSE(关闭)状态,到此服务器的连接已经完成 关闭。客户端处于 TIMEWAIT 状态时,此时的 TCP 还未释放掉,需要 等待 2MSL 后,客户端才进入 CLOSE 状态。

3.二者区别

  • 三次握手是建立连接的过程,四次握手是关闭连接的过程。
  • 建立连接时,客户端和服务器需要交换三个数据包;关闭连接时,需要交换四个数据包。
  • 四次握手中,最后一个ACK是为了确认服务器已经接收到了客户端的关闭请求,防止出现丢失的情况。在三次握手中,最后一个ACK是用来确认客户端已经接收到服务器的同意连接请求。

总体来说,三次握手和四次握手是TCP连接的建立和关闭的标准过程,确保通信双方的状态同步和数据的可靠传输。

相关实践学习
通过Ingress进行灰度发布
本场景您将运行一个简单的应用,部署一个新的应用用于新的发布,并通过Ingress能力实现灰度发布。
容器应用与集群管理
欢迎来到《容器应用与集群管理》课程,本课程是“云原生容器Clouder认证“系列中的第二阶段。课程将向您介绍与容器集群相关的概念和技术,这些概念和技术可以帮助您了解阿里云容器服务ACK/ACK Serverless的使用。同时,本课程也会向您介绍可以采取的工具、方法和可操作步骤,以帮助您了解如何基于容器服务ACK Serverless构建和管理企业级应用。 学习完本课程后,您将能够: 掌握容器集群、容器编排的基本概念 掌握Kubernetes的基础概念及核心思想 掌握阿里云容器服务ACK/ACK Serverless概念及使用方法 基于容器服务ACK Serverless搭建和管理企业级网站应用
相关文章
|
8月前
|
前端开发 网络协议 JavaScript
|
2月前
|
网络协议
三次握手,四次挥手
【10月更文挑战第25天】三次握手和四次挥手是 TCP 协议中确保可靠网络通信的重要机制,它们通过一系列的交互过程,保证了连接的正确建立和有序关闭,以及数据的可靠传输和资源的合理释放,从而为网络应用提供了稳定、可靠的通信基础。
|
4月前
|
运维 网络协议
深入解析TCP三次握手与四次挥手:建立与断开连接的关键过程
深入解析TCP三次握手与四次挥手:建立与断开连接的关键过程
297 0
|
8月前
|
网络协议 网络架构
三次握手与四次挥手
三次握手与四次挥手
|
8月前
|
移动开发 网络协议 API
三次握手与四次挥手在具体函数上的体现
三次握手与四次挥手在具体函数上的体现
58 0
|
网络协议
TCP的连接管理机制(三次握手与四次挥手)
TCP的连接管理机制(三次握手与四次挥手)
88 0
|
缓存 网络协议 安全
TCP通信机制:三次握手、四次挥手、滑动窗口
TCP通信机制:三次握手、四次挥手、滑动窗口
807 1
TCP通信机制:三次握手、四次挥手、滑动窗口
|
网络协议 网络性能优化
网络通信——TCP “三次握手“、“四次挥手“ 详解
TCP三次握手和四次挥手是面试题的热门考点,它们分别对应TCP的连接和释放过程
网络通信——TCP “三次握手“、“四次挥手“ 详解
|
缓存 网络协议 安全
TCP三次握手四次挥手及常见问题解决方案
TCP三次握手四次挥手及常见问题解决方案
TCP三次握手四次挥手及常见问题解决方案
|
网络协议
TCP通信过程的三次握手和四次握手
TCP通信过程的三次握手和四次握手
156 0
TCP通信过程的三次握手和四次握手

热门文章

最新文章