TCP的连接管理机制(三次握手与四次挥手)

简介: TCP的连接管理机制(三次握手与四次挥手)

为啥要三次握手与四次挥手


相比于UDP, TCP是有连接的, 这个连接就体现在这了.


三次握手就是TCP建立连接, 四次挥手就是TCP断开连接.


三次握手


握手是指通信双方进行网络交互.

三次握手就相当于是 客户端与服务器间通过三次交互来建立连接关系.

(建立连接关系, 本质就是双方记录对方信息)


要了解三次握手, 首先我们还得来了解 syn报文 与 ack报文.


syn 与 ack


syn 称为同步报文段, 意思是一方要向另一方申请建立连接.

ack 是确认字符, 表示发来的数据已经接收无误.


报文具体结构是怎样的呢?


dfcc634e1729447aa2bc10bd3e96bc2a.png

什么样的报文是 syn 报文呢?

观察TCP报头结构, 我们可以看到在 16为窗口大小 左边有六个特殊比特位, 这些比特位默认为0, 如果为 1, 则表示其特殊含义.

比如, 第二位是 ack, 如果这一位为 1, 则表示当前数据报是一个应答报文.

同样的, 第五位是 syn, 如果为 1, 则表示当前数据报是一个同步报文.

如果一个TCP数据报, 第二位和第五位都是1, 那么就是 ack + syn 报文.


三次握手具体流程


如下图 :

c7a0de10f5d644c1addfddcfa6d78347.png


  1. 客户端请求同步, 也就是发送 syn.
  2. 服务器接收到 syn, 就需要进行应答, 就发送了 ack, 同时也要与客户端请求同步, 就发送了 syn, 因为是同时发生的, 所以就包含在了一个数据报中, 也就是一次握手了.
  3. 客户端接收到数据报后, 也要返回一个响应, 表示收到数据报, 就返回 ack.


其实三次握手就相当于投石问路, 测试客户端与服务器是否具有发送与接收数据的能力.

这是后续可靠传输的基础.

我们可以类比成两个人在网上进行语音通话 :


当甲乙双方连上麦后, 就得测试一下是否有问题.

首先甲说一句 : “听得到我说话吗?”

乙听到后就得响应甲, 说 : “听到了, 你听到我说话吗?” (这里乙就知道了, 甲的发送能力没问题, 乙的接收能力也没问题)

甲听到乙说话后, 就再回一句 : “听到了” (这里甲就知道了, 乙的接收发送能力没问题, 甲的接收发送也没问题)

最后就是乙收到甲的消息, 明白了甲的接收能力没问题, 乙的发送也没问题.

至此, 甲乙双方都测试出了两方的发送与接收没问题.


注意 :


上述过程是内核自动完成, 应用程序干预不了.

等到三次握手完成后, 就建立连接了, 服务器的 accept 把建立好的连接从内核拿到应用程序中.


四次挥手


就是双方断开连接, 来看下图 :


4c287115ee57489fa80cf88b0570857e.png


  1. 客户端向服务器发送 fin(结束报文), 通知服务器 “我要与你断开连接了”.
  2. 服务器收到后, 就返回 ack, 就是响应服务器的通知, 相当于 “我知道了”.
  3. 服务器执行到了 clos 方法后也发送通知, 说 “我也要与你断开连接了”.
  4. 客户端收到后返回 ack 响应, 相当于说 “好的”.

我们这情况很类似与三次握手, 是否可以把四次挥手变为三次挥手呢? (将ack与fin和并)

其实, ack 与 fin 是有一定的概率和并的, 但通常情况下不能和并.

为什么三次握手的第二次握手能和并, 而这里就不行呢?


三次握手, ack 和 syn 都是在同一时机触发的 (都是内核来完成的)

四次挥手, ack 与 fin 的触发时机不同.


ack 是内核完成的, 在收到 fin 的第一时间会返回.

fin 则是应用程序代码控制的, 在调用 socket 的 close 的方法的时候才会返回 fin.


如果趁着 ack 还没发就 close, 则可以进行和并.


其实客户端之所以发送 fin, 也是因为客户端进程执行到了 close 方法(即使代码中没有调用 close 方法, 在进程结束时也会自动进行执行 close), 释放资源.

此时客户端进程虽然结束了, 但是 tcp 连接还在, 内核还是会把 tcp 连接继续维护, 直到四次挥手完成. 服务这边也是一样.


注意


建立连接, 一定是客户端先发起.

断开连接, 双方都有可能先发起.


相关实践学习
通过Ingress进行灰度发布
本场景您将运行一个简单的应用,部署一个新的应用用于新的发布,并通过Ingress能力实现灰度发布。
容器应用与集群管理
欢迎来到《容器应用与集群管理》课程,本课程是“云原生容器Clouder认证“系列中的第二阶段。课程将向您介绍与容器集群相关的概念和技术,这些概念和技术可以帮助您了解阿里云容器服务ACK/ACK Serverless的使用。同时,本课程也会向您介绍可以采取的工具、方法和可操作步骤,以帮助您了解如何基于容器服务ACK Serverless构建和管理企业级应用。 学习完本课程后,您将能够: 掌握容器集群、容器编排的基本概念 掌握Kubernetes的基础概念及核心思想 掌握阿里云容器服务ACK/ACK Serverless概念及使用方法 基于容器服务ACK Serverless搭建和管理企业级网站应用
相关文章
|
8月前
|
网络协议 Python
TCP传输的三次握手、四次挥手策略是什么
TCP传输的三次握手、四次挥手策略是什么
59 0
|
3月前
|
网络协议
【TCP】连接管理:三次握手和四次挥手
【TCP】连接管理:三次握手和四次挥手
56 3
|
4月前
|
运维 网络协议
深入解析TCP三次握手与四次挥手:建立与断开连接的关键过程
深入解析TCP三次握手与四次挥手:建立与断开连接的关键过程
297 0
|
7月前
|
网络协议
TCP传输的三次握手四次挥手策略
TCP传输的三次握手四次挥手策略
43 0
|
8月前
|
网络协议
TCP协议中用于建立和终止连接的过程(三次握手,四次挥手)
TCP协议中用于建立和终止连接的过程(三次握手,四次挥手)
54 0
|
网络协议 安全
网络:TCP协议三次握手与四次挥手
网络:TCP协议三次握手与四次挥手
86 0
|
8月前
|
网络协议
TCP三次握手,四次挥手策略
TCP三次握手,四次挥手策略
34 0
|
8月前
|
缓存 网络协议 算法
深入理解Linux网络——TCP协议三次握手和四次挥手详细流程
• 找到套接字:创建内核对象的时候,fd会跟file对象做通过fd_install关联起来,通过进程的fd_table就可以找到对应的file,而file的private指针就指向了socket对象,所以根据fd即可找到套接字 • 判断当前套接字的状态:只有SS_UNCONNECTED状态(刚创建的套接字就是该状态)才会继续,其他状态都会报错 1. 注意此处是socket的状态,而不是sock的状态 2. 会将socket状态更改为SS_CONNECTING • 更改sock状态为TCP_SYN_SENT
|
网络协议
【网络基础】TCP三次握手和四次挥手
传输控制协议(TCP,Transmission Control Protocol)是一种面向连接的、可靠的、基于字节流的传输层通信协议,由IETF的RFC
75 0
|
网络协议 网络性能优化
网络通信——TCP “三次握手“、“四次挥手“ 详解
TCP三次握手和四次挥手是面试题的热门考点,它们分别对应TCP的连接和释放过程
网络通信——TCP “三次握手“、“四次挥手“ 详解

热门文章

最新文章