详解TCP的三次握手和四次挥手

文章目录

      • 1. TCP报文的头部结构
      • 2. 三次握手的原理与过程
        • 三次握手
        • 连接建立过程解析
      • 3. 四次挥手的原理与过程
        • 四次挥手
        • 连接关闭过程的解析
      • 4. 常见面试题


深入理解TCP连接:三次握手和四次挥手

在网络通信中,TCP(传输控制协议)扮演着重要的角色。TCP是一种面向连接的、可靠的、基于字节流的传输层通信协议,它在发送数据前,通信双方必须在彼此间建立一条连接。本文将深入探讨TCP连接的建立和断开过程,着重关注三次握手和四次挥手的原理和过程。

1. TCP报文的头部结构

在了解TCP连接之前,先来了解一下TCP报文的头部结构。TCP报文头部包含了多个字段,其中包括序号、确认序号、标志位等。这些字段在TCP连接的建立和断开过程中起着重要作用。
在这里插入图片描述

  • 序号(Seq Number):占32位,用于标识从TCP源端向目的端发送的字节流,发起方发送数据时对此进行标记。
  • 确认序号(Ack Number):占32位,只有ACK标志位为1时,确认序号字段才有效。确认序号通常等于对方发送的序号加一,表示已经成功接收到了这个序号之前的所有数据。
  • 标志位:共6个,包括:
    • ACK:确认序号有效。
    • FIN:释放一个连接。
    • PSH:接收方应该尽快将这个报文交给应用层。
    • RST:重置连接。
    • SYN:发起一个新连接。
    • URG:紧急指针(urgent pointer)有效。

2. 三次握手的原理与过程

三次握手的本质是确认通信双方收发数据的能力首先,我让信使运输一份信件给对方,对方收到了,那么他就知道了我的发件能力和他的收件能力是可以的。一个TCP连接由一个4元组构成,分别是两个IP地址和两个端口号。TCP连接通常分为三个阶段:连接、数据传输、退出(关闭)。连接阶段通过三次握手建立,退出阶段通过四次挥手来关闭。

三次握手

举个栗子先吧

想象一下,有两位朋友,小明和小红,他们之间需要通过写信来进行交流。这个过程就像是建立TCP连接的三次握手。

  1. 第一次握手:小明发出邀请

    小明向小红写了一封信,表达了与她建立联系的意愿,并附上了自己的联系方式。这相当于客户端向服务器发送连接请求报文,带有一个序列号和请求信息,并携带了SYN 标志。

  2. 第二次握手:小红确认邀

    小红收到了小明的信后,理解了他想要与她通信的意图,并写了回信给小明,确认了自己的联系方式,并附上了自己的联系方式。这封回信相当于服务器对客户端的回应,其中包含了确认信息和服务器的序列号,并带有SYNACK 标志。

  3. 第三次握手:小明回复确认

    小明收到了小红的回信后,确认了小红的联系方式,并回复了一封信给小红,表明自己已经收到了小红的回信,并准备好开始正式的通信。这封回复信相当于客户端对服务器的确认,其中包含了确认信息,并带有 ACK 标志。

通过这样的三次交流,小明和小红建立了可靠的通信连接,并可以开始进行进一步的交流。

连接建立过程解析

img

在TCP连接建立的过程中,这三次握手实际上包含了以下步骤:

  1. 第一次握手:客户端发送连接请求

    客户端向服务器发送一个带有SYN 标志的连接请求报文,其中包含了一个随机生成的序列号。

  2. 第二次握手:服务器确认连接请求

    服务器收到连接请求后,发送一个带有SYN和ACK 标志的确认报文,其中包含了确认号(客户端序列号+1)和服务器自己的随机生成的序列号。

  3. 第三次握手:客户端确认连接

    客户端收到服务器的确认后,发送一个带有ACK 标志的确认报文,其中包含了确认号(服务器序列号+1)。

通过这三次握手,客户端和服务器建立了可靠的通信连接,可以开始进行数据传输。

3. 四次挥手的原理与过程

在TCP(Transmission Control Protocol)连接中,四次挥手是用于关闭连接的过程。尽管这个过程相对于三次握手来说更为复杂,但通过详细的解析,我们可以更好地理解其中的每个步骤和顺序。

四次挥手

为了更好地理解TCP四次挥手的过程,我们可以用一个简单的比喻来解释:

想象一下,有两位朋友,小明和小红,他们之间通过书信往来进行交流。这个过程就像是TCP连接的四次挥手。

  1. 第一次挥手:小明发出告别

    当小明觉得与小红的交流结束时,他首先向小红发送一封告别信,表明自己不再需要继续通信。这封信中包含了一个FIN 标志位,表示告知对方已经不会再发送数据了,以及一个序列号,表示最后一个已发送的数据的序列号。

  2. 第二次挥手:小红确认告别

    小红收到了小明的告别信后,确认了小明不再需要继续通信,并向小明回复了一封确认信,表示自己已经知道了小明的意图。这封确认信中包含了一个ACK 标志位和一个确认号,确认了小明的序列号,并且也包含了小红自己的序列号。

  3. 第三次挥手:小红告别

    小红在确认了小明的告别后,也觉得不再需要继续通信,于是她向小明发送了一封告别信,表示自己不会再发送数据了。这封信中包含了一个FIN 标志位和一个序列号,表示告知小明自己不会再发送数据了。

  4. 第四次挥手:小明确认告别

    小明收到小红的告别信后,确认了小红的意图,并向小红回复了一封确认信,表示自己已经知道了小红不再发送数据的意图。这封确认信中包含了一个ACK 标志位和一个确认号,确认了小红的序列号,并且表示自己不会再发送数据了。

通过这四次挥手,小明和小红完成了通信的结束,彼此知道对方不再发送数据,并且关闭了连接。

连接关闭过程的解析

img

接下来,我们来详细分析每个步骤中的具体内容和顺序:

  1. 第一次挥手:客户端发送连接释放报文

    客户端在确定不再发送数据后,向服务器发送一个带有FIN 标志的连接释放报文,其中包含了一个序列号,表示客户端最后一个已发送的数据的序列号。

  2. 第二次挥手:服务器确认连接释放报文

    服务器收到客户端发送的连接释放报文后,回复一个带有ACK 和确认号的确认报文,表示已经收到了客户端的连接释放请求,并且确认了客户端的序列号。

  3. 第三次挥手:服务器发送连接释放报文

    服务器在确定不再发送数据后,向客户端发送一个带有FIN 标志的连接释放报文,其中包含了一个序列号,表示服务器最后一个已发送的数据的序列号。

  4. 第四次挥手:客户端确认连接释放报文

    客户端收到服务器发送的连接释放报文后,回复一个带有ACK 和确认号的确认报文,表示已经收到了服务器的连接释放请求,并且确认了服务器的序列号。

通过这四次挥手,客户端和服务器完成了连接的关闭,彼此确认不再发送数据,并且释放了连接资源。

4. 常见面试题

为什么TCP连接的时候是3次?2次不可以吗?

  • 因为需要考虑连接时丢包的问题,如果只握手2次,第二次握手时如果服务端发给客户端的确认报文段丢失,此时服务端已经准备好了收发数(可以理解服务端已经连接成功)据,而客户端一直没收到服务端的确认报文,所以客户端就不知道服务端是否已经准备好了(可以理解为客户端未连接成功),这种情况下客户端不会给服务端发数据,也会忽略服务端发过来的数据。如果是三次握手,即便发生丢包也不会有问题,比如如果第三次握手客户端发的确认ack报文丢失,服务端在一段时间内没有收到确认ack报文的话就会重新进行第二次握手,也就是服务端会重发SYN报文段,客户端收到重发的报文段后会再次给服务端发送确认ack报文。

为什么TCP连接的时候是3次,关闭的时候却是4次?

  • 因为只有在客户端和服务端都没有数据要发送的时候才能断开TCP。而客户端发出FIN报文时只能保证客户端没有数据发了,服务端还有没有数据发客户端是不知道的。而服务端收到客户端的FIN报文后只能先回复客户端一个确认报文来告诉客户端我服务端已经收到你的FIN报文了,但我服务端还有一些数据没发完,等这些数据发完了服务端才能给客户端发FIN报文(所以不能一次性将确认报文和FIN报文发给客户端,就是这里多出来了一次)。

为什么客户端发出第四次挥手的确认报文后要等2MSL的时间才能释放TCP连接?

  • 这里同样是要考虑丢包的问题,如果第四次挥手的报文丢失,服务端没收到确认ack报文就会重发第三次挥手的报文,这样报文一去一回最长时间就是2MSL,所以需要等这么长时间来确认服务端确实已经收到了。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/579276.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Qt中的多线程

视频链接:https://www.bilibili.com/video/BV1iN411f7dY/?p2&spm_id_frompageDriver&vd_sourcefa4ef8f26ae084f9b5f70a5f87e9e41b 在Qt中使用多线程可以提高用户体验,若只有一个线程进行处理,则会导致窗口卡顿,这是我们不…

go-python 库使用详解

1. 引言 在当今软件开发领域,跨语言编程已经成为一种常见的需求。不同的编程语言各自有其优势和适用场景,因此在项目开发过程中,经常需要将多种编程语言进行集成和协作。Go语言(简称Go)和Python作为两种流行的编程语言…

iOS - Runloop介绍

文章目录 iOS - Runloop介绍1. 简介1.1 顾名思义1.2. 应用范畴1.3. 如果没有runloop1.4. 如果有了runloop 2. Runloop对象3. Runloop与线程4. 获取Runloop对象4.1 Foundation4.2 Core Foundation4.3 示例 5. Runloop相关的类5.1 Core Foundation中关于RunLoop的5个类5.2 CFRunL…

北京小蓝蜂科技有限公司 基本情况

北京小蓝蜂科技有限公司 基本情况 公司概述 北京小蓝蜂科技有限公司(简称“小蓝蜂”)是一家专注于互联网行业的公司,成立于4年前,位于北京市海淀区成府路45号中关村智造大街G座一层J030。小蓝蜂主要业务包括技术开发、技术咨询、技术转让、技术推广等,同时也涉及销售自行…

【Go】六、函数

文章目录 1、函数的定义2、内存分析3、注意点4、函数数据类型5、自定义数据类型(起别名)6、支持对返回值命名 1、函数的定义 语法: func 函数名(形参列表)(返回值类型列表){执行语句..return 返回值列…

公司官网怎么才会被百度收录

在互联网时代,公司官网是企业展示自身形象、产品与服务的重要窗口。然而,即使拥有精美的官网,如果不被搜索引擎收录,就无法被用户发现。本文将介绍公司官网如何被百度收录的一些方法和步骤。 1. 创建和提交网站地图 创建网站地图…

学俄语能不能直接学口语,而不学语法?柯桥俄语培训

语言属性决定,俄语入门就要学语法! 俄语教学实践已经证明,俄语语法必须要学,而且优先学。 这是为什么呢? 这是由俄语本身的特性决定。俄语属屈折语,其典型特征便是以丰富的词形变化来表达词与词之间的关…

QML通过鼠标拖动的位置

当通过鼠标拖动Rectangle 的位置时,可以使用Qt Quick的MouseArea组件来实现 Rectangle {id: rectx:0;y:0width: 200; height: 100color: "lightblue"MouseArea {id: mouseAreaanchors.fill: parentdrag.target: rect//要拖动的项目的IDdrag.axis: Drag.XA…

蓝桥杯算法题-图形排版

题目描述 小明需要在一篇文档中加入 N 张图片,其中第 i 张图片的宽度是 Wi,高度是 Hi。   假设纸张的宽度是 M,小明使用的文档编辑工具会用以下方式对图片进行自动排版: 1. 该工具会按照图片顺序,在宽度 M 以内&…

基于java高校社团招新系统设计与实现

摘要 :大学学生社团的不断壮大发展,让对社团的招新管理越来越重要,如何高效的管理社团,促进社团有效的运行和发展变得尤为关键。学生社团在学生的成长发展过程中有着一定的积极作用,要发挥好社团的优势,管…

商品数据化运营---初步整理

商品数据化运营是指利用数据分析技术来优化商品的销售、管理和推广过程。这种方法结合了数据科学、商业智能、市场分析和消费者行为研究等多个领域的技术和理论,旨在通过分析大量的商品和销售数据来提高商品的市场表现和企业的利润。 以下是商品数据化运营的一些关…

哪里脏扫哪里,脏污识别将成扫地机器人下一个“卷”点?

让“人工式”清洁成为可能。 同质化竞争中的下一个“卷”点? 对于扫地机器人而言,脏污识别并非是个新概念,从2022年开始就有厂商提出,只是相较于其它方面的“内卷”,厂商们最初对它的重视程度并不高,目前脏…