TCP——三次握手和四次挥手

简介: TCP——三次握手和四次挥手

文章目录

三次握手

四次挥手


三次握手


TCP协议目的是为了保证数据能够在两端准确连续的流动,可以想象两个建立起TCP通道的设备如同接起了一根水管,数据就是水管种的水由一头流向了另一头。然而TCP为了能让一个设备连接多个水管,也就是让一个设备同时与多个设备交互信息,它必须保证不同水管之间不能产生串联或相互影响。


为了确保数据能够正确分发,TCP用一种叫TCB(传输控制块)的数据结构把发给不同设备的数据封装起来,我们可以把该结构看作是信封。一个TCB数据块包含了数据发送双方对应的socket信息以及拥有装载数据的缓冲区。


在两个设备要建立连接发送数据之前,双方都必须做一些准备–分配内存建立起TCB数据块

1.png

1、准备工作

最开始的客户端和服务器都处于CLOSE状态。主动打开连接的是客户端,被动打开的是服务器

TCP服务器进程先创建传输控制块TCB,时刻准备接收客户端进程的请求,此时服务器就进入LISTEN状态


2、一次握手

TCP客户端也是先创建了传输控制块TCB,然后向服务器发出连接请求报文,SYN,报文首部种的同部位(SYN=1),同时选择一个序列号seq=x

此时,TCP进入SYN-SENT(同步已发送状态)。TCP规定,SYN报文段不能携带数据,但需要消耗一个序号

如果是发送,则需要发送一个标志位SYN=1,同时选择一个初始序列号seq=x(随机,客户端或服务器每发送一次+1)


3、二次握手

TCP服务器收到请求报文后,如果同意连接,则发出确认报文。

收到报文,则需要发送一个确认标志位ACK=1,并且确认序列号ack=x+1,然后发出报文,需要一个发送标志位SYN=1,同时选择一个初始序列号seq=y(随机)


4、TCP客户端收到确认后,还要向服务器给出确认。

收到报文,发送一个确认标志位ACK=1,确认序列号ack=y+1,seq=x+1 。

为什么TCP客户端还要最后再发一次确认呢


主要防止已经失效的连接请求报文又突然传送到了服务器,从而产生错误

1.png


四次挥手


数据传输完毕后,双方都可释放连接。最开始的时候,客户端和服务器都是处于established状态。然后客户端主动关闭,服务器被动关闭。

1.png

1、TCP客户端收到一个FIN(关闭连接),用来关闭客户端到服务器的数据传送


2、服务器收到这个FIN,它发回一个ACK

客户端发送完所有的数据,请求关闭连接,向服务器申请关闭,但与此同时,服务器未必就把所有的数据全部向客户端发送完毕,所以在第二步和第三步之间,服务器可以继续数据传输


3、服务器关闭客户端的连接,发送一个FIN给客户端


4、客户端发回ACK报文确认,并将确认序号设置为收到序号+1


为什么客户端最后还要等待2MSL


去向ACK消息最大存活时间(MSL)+ 来向FIN消息的最大存活时间(MSL)


第一,保证客户端发送的最后一个ACK报文能够到达服务器


第二,释放的端口可能重连刚断开的服务器端口,这样依然存活在网络里的老的TCP报文可能与新的TCP连接报文冲突


如果已经建立连接了,但是客户端突然出现故障了怎么办


TCP还设有一个保活计时器。客户端出现故障,服务器不能一直等下去


TCP协议是如何保证可靠传输的


数据包校验:目的是检测数据在传输过程中的任何变化,若校验出包有错,则丢弃报文段并且不给出响应,这时 TCP 发送数据端超时后会重发数据;

对失序数据包重排序:既然 TCP 报文段作为 IP 数据报来传输,而 IP 数据报的到达可能会失序,因此 TCP 报文段的到达也可能会失序。TCP 将对失序数据进行重新排序,然后才交给应用层;

丢弃重复数据:对于重复数据,能够丢弃重复数据;

应答机制:当 TCP 收到发自 TCP 连接另一端的数据,它将发送一个确认。这个确认不是立即发送,通常将推迟几分之一秒;

超时重发:当 TCP 发出一个段后,它启动一个定时器,等待目的端确认收到这个报文段。如果不能及时收到一个确认,将重发这个报文段;

流量控制:TCP 连接的每一方都有固定大小的缓冲空间。TCP 的接收端只允许另一端发送接收端缓冲区所能接纳的数据,这可以防止较快主机致使较慢主机的缓冲区溢出,这就是流量控制。TCP 使用的流量控制协议是可变大小的滑动窗口协议。

相关实践学习
通过Ingress进行灰度发布
本场景您将运行一个简单的应用,部署一个新的应用用于新的发布,并通过Ingress能力实现灰度发布。
容器应用与集群管理
欢迎来到《容器应用与集群管理》课程,本课程是“云原生容器Clouder认证“系列中的第二阶段。课程将向您介绍与容器集群相关的概念和技术,这些概念和技术可以帮助您了解阿里云容器服务ACK/ACK Serverless的使用。同时,本课程也会向您介绍可以采取的工具、方法和可操作步骤,以帮助您了解如何基于容器服务ACK Serverless构建和管理企业级应用。 学习完本课程后,您将能够: 掌握容器集群、容器编排的基本概念 掌握Kubernetes的基础概念及核心思想 掌握阿里云容器服务ACK/ACK Serverless概念及使用方法 基于容器服务ACK Serverless搭建和管理企业级网站应用
相关文章
|
6月前
|
网络协议 网络架构
|
7月前
|
网络协议
TCP三次握手和四次挥手
TCP三次握手和四次挥手
|
7月前
|
网络协议
|
7月前
|
网络协议
说说TCP为什么需要三次握手和四次挥手? _
TCP连接的建立需要三次握手,确保双方的接收和发送能力正常,而关闭连接则涉及四次挥手以确保数据传输完成。这个过程包括客户端发送SYN开始连接,服务器响应SYN并ACK,然后客户端再次ACK确认连接建立。终止连接时,客户端发送FIN,服务器回ACK,服务器发送FIN,最后客户端再发送ACK确认关闭。四次挥手的目的是防止已失效的连接请求报文突然传到服务器,导致不必要的资源消耗。
|
7月前
|
网络协议
TCP的三次握手和四次挥手
TCP的三次握手和四次挥手
42 0
|
7月前
|
网络协议
TCP三次握手 四次挥手
TCP三次握手 四次挥手
|
7月前
|
缓存 网络协议 数据处理
TCP中的三次握手和四次挥手
我们知道TCP是运输层的面向连接的可靠的传输协议。**面向连接的**,指的就是在两个进程发送数据之前,必须先相互“握手”,确保两进程可以进行连接。并且这个传输是点对点的,即一个TCP连接中只有一个发送方和接收方;**可靠的**,指的是在任何网络情况下,在TCP传输中数据都将完整的发送到接收方。
73 0
TCP中的三次握手和四次挥手
|
网络协议
tcp三次握手与四次挥手
tcp三次握手与四次挥手
101 0
|
网络协议 网络安全
对TCP三次握手四次挥手的理解
对TCP三次握手四次挥手的理解
137 0
对TCP三次握手四次挥手的理解
|
网络协议
TCP三次握手与四次挥手
TCP三次握手与四次挥手
164 0