TCP可靠连接的建立和释放,TCP报文段的格式,UDP简单介绍

TCP连接的建立(三次握手)

建立连接使用的三报文 

SYN 报文仅用于 TCP 三次握手中的第一个和第二个报文(SYN 和 SYN-ACK),用于初始化连接的序列号。数据传输阶段不再使用 SYN 标志。 SYN 报文通常只携带连接请求信息,并不包含实际的数据负载。

ACK表明这是一个确认报文。

seq(序列号) 是一个用于追踪每个字节流位置的编号,它确保数据传输的可靠性和有序性。序列号的作用是帮助接收方和发送方正确重组数据,即使数据包顺序错乱或丢失,也能通过序列号将其还原到正确的位置。双方的序列号(Seq)并没有直接的本质联系。每个方向的序列号是独立的,只是它们在各自方向上保持连续性。

ps:在tcp建立连接握手阶段,虽然还尚未发送数据,但是可以看到这里第三个报文和第一个报文相比,序列号增加了1。因为即使没有数据传输,每次握手中的 SYN 报文都会消耗一个序列号

确认号 (ack):如果接收方的最后一个成功接收的数据字节的序列号为 N,那么接收方会在 ACK 中发送确认号 N + 1,表示接收方已经成功接收到了序列号 N 之前的所有字节,并且期望接收序列号为 N + 1 的字节。ack=seq+1

为什么建立TCP连接不能使用两报文?

避免旧的连接请求引发的误连接
如果采用两次握手,假设客户端发送一个 SYN 报文请求建立连接,然后因网络延迟,该报文被滞留在网络中。如果此时服务器没有接到确认就直接建立连接,当滞留的 SYN 报文到达后,服务器可能误以为客户端请求重新连接,错误地建立新的连接。三次握手的第三次 ACK 则能有效避免这一问题,因为旧 SYN 报文不会收到匹配的第三次握手确认,避免了误连接的发生。

如果采用两报文握手,那么将会是下面这样的情况:

如果采用两次握手建立连接,当TCP服务器端收到网络中已经失效的TCP连接请求之后,也会以为是客户机发来的连接请求,直接进入连接状态/但是客户机这边可能已经关闭了tcp连接,此时并不需要tcp服务传送数据,但是服务器端始终保持着这些无效连接,造成了tcp连接资源的浪费 

TCP连接建立的一道例题

这道题选项中,主机乙选择的初始seq正好与报文要回应的主机甲的ack一样,看起来有点别扭。

TCP连接的释放(四次挥手)

释放连接使用的四报文

1.主动关闭方发送 FIN(Finish)报文

  • 发送方(客户端或服务器) 发送一个 FIN 报文段,表示数据发送完毕,不再发送数据。这一步是主动关闭连接的一方(通常是客户端)发出的。
  • FIN 报文中的 SEQ 字段表示最后一个字节的序列号(即发送方最后一个字节的序列号),告诉接收方发送方已经完成数据发送。

2. 被动关闭方回复 ACK 报文

  • 接收方(另一方,通常是服务器或客户端) 收到 FIN 报文后,会发送一个 ACK 报文,确认已经收到对方的 FIN 请求,序列号为 接收方的下一个序列号
  • 这个 ACK 报文的确认号是 FIN 的序列号 + 1,表示已经收到 FIN 报文。

3. 被动关闭方发送 FIN 报文

  • 在发送 ACK 报文后,被动关闭方(比如服务器)会准备关闭连接,发送一个 FIN 报文,表示自己也没有数据要发送,准备关闭连接。
  • 这个 FIN 报文和连接的正常数据包一样,包含一个 SEQ 字段,表示自己最后发送的数据字节的序列号。

4. 主动关闭方回复 ACK 报文

  • 主动关闭方(客户端或服务器) 收到 FIN 报文后,会发送一个 ACK 报文来确认接收方的 FIN 请求,表示连接完全关闭。但是此时主动关闭方并不会直接变为close状态,而是进入一个时长为2MSL的时间等待状态,为了确保对方收到了最后的 ACK 报文,即便是 ACK 丢失,被动关闭方重发的 FIN 报文也可以被主动关闭方处理,从而保证连接双方的一致性。
  • 此时,确认号是 对方的 FIN 序列号 + 1

为什么需要四次挥手?

  1. 每方都要告知对方自己没有数据要发送:由于 TCP 是全双工的协议,连接的关闭是单独的。每个方向的数据流都需要单独关闭,因此需要四次挥手。
  2. 保证数据的完整性:每一方都确保对方确认自己所有的数据已经被接收并且完全关闭连接。

为什么选择设计TCP连接可单向解除?

当主动关闭方发送 FIN 请求断开连接,并得到被动关闭方的 ACK 确认后,主动关闭方会停止数据的发送,但依然会继续接收来自被动关闭方的数据。

  • 确保数据传输完整性
    如果主动关闭方在发送 FIN 后立刻关闭接收通道,则可能导致被动关闭方尚未传输的数据被丢弃。通过保持接收通道的开放,即使主动关闭方停止发送数据,它仍可以接收被动关闭方的剩余数据,确保任何未完成的数据传输不会因为连接关闭而丢失。

  • 支持渐进式的双向关闭
    在实际应用中,有时主动关闭方可能已经不需要发送更多数据,但被动关闭方仍然有待传输的数据。例如,当客户端请求断开连接时,服务器可能仍有一些待发送的响应或日志。通过分离关闭方向,TCP 允许服务器在完成数据发送后再发送 FIN 请求来正式关闭连接,从而实现一个更优雅的连接终止过程。

TCP连接/释放推荐参考视频:

5.8.2 TCP的运输连接管理—TCP的连接释放_哔哩哔哩_bilibili

【复试自用计算机网络】TCP连接建立的三次握手+TCP连接断开的四次握手_哔哩哔哩_bilibili

TCP报文段的首部格式 

 

 

  • 源端口号:标识发送方应用程序的端口号,通常由发送方操作系统动态分配(除非应用程序指定固定端口号)。
  • 目的端口号:标识接收方应用程序的端口号,通常是由接收方服务或应用程序指定。例如,HTTP 服务通常使用端口 80,HTTPS 使用端口 443。
  • 序列号:表示报文段中数据的第一个字节的编号,用于确保数据的顺序传输和重组。在建立连接的第一次握手(SYN)中,序列号会作为初始序列号(ISN)发送。
  • 确认号:确认号是接收方发送给发送方的一个字段,表示接收方期望收到的下一个字节的序列号。TCP 使用这个字段来实现确认机制,确保数据的可靠传输。
  • 数据偏移:指出 TCP 报文段首部的总长度,以 32 位字(4 字节)为单位。这一字段帮助接收方知道数据从报文段的哪个位置开始。(由于tcp报文段的首部包含拓展首部,其长度不固定,而我们首部总长度又必须要求为4字节的倍数,所以拓展首部的后面有填充字段,用来帮助首部长度凑为4的倍数)
  • 关于后面的几个字段这里也不详细一一介绍了,可以观看视频:5.9 TCP报文段的首部格式_哔哩哔哩_bilibili

关于tcp首部中序列号和确认号的详细解释

当 TCP 连接建立时,双方都会生成一个 初始序列号(ISN)。这个初始序列号通常是一个 随机数,而不是固定的 0。使用随机的 ISN 是为了提高安全性,防止 序列号预测攻击(例如,攻击者利用已知的序列号猜测数据流)。

tcp数据报其中包含的数据字节都会按顺序编号,并且每个字节都会分配一个唯一的序列号。发送报文的序列号是 连续增长 的,即每发送一个新的数据段,序列号就会增加相应的数量。虽然一个报文段中可以包含若干字节,但是一个tcp数据报中的序列号只填入这个数据报中的第一个字节的编号。

  • 假设初始序列号 ISN = X,发送方发送了一个包含 N 字节数据的报文段。则该报文段的序列号为 X,而确认号会是 X + N(即对方期望接收的下一个字节的序列号)。
  • 下一个报文段的序列号将是 X + N,并且它会继续递增,直到所有的数据都发送完。
  • 注意: 序列号是按字节递增的,而不是报文段递增。这意味着每个数据字节都有一个唯一的序列号。

确认号(ACK)是 TCP 报文段头中的一个字段,表示接收方期望下一个收到的数据字节的序列号。它用于确认已经成功接收到的数据,并告诉发送方接收方期望接收的下一个字节。

序列号和确认号是密切联系配合的!!!

  • 发送方:
    • 发送方在发送数据时会给数据报文段分配序列号。序列号表示该报文段中的数据相对于字节流的偏移量。
  • 接收方:
    • 接收方收到数据后,会根据自己期望的下一个字节的序列号来发送确认号。接收方的确认号是 期望接收到的下一个字节的序列号
    • 例如,如果接收方已经收到了序列号为 10001500 的数据,那么它的确认号会是 1501,表示它已经收到并确认了 10001500 的数据,期望收到下一个字节 1501

UDP简单介绍 

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

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

flink 同步oracle11g数据表到pg库

1. 关闭防火墙和selinux systemctl stop firewalld systemctl disable firewalld systemctl status firewalldvi /etc/selinux/config 修改为disabled2.安装java8 yum list java-1.8* yum install java-1.8.0-openjdk* -yjava -version3.下载和部署postgresql 看需求安装pg库…

012_SSH_Mysql网上订餐系统(论文+程序)_lwplus87

摘 要 本文讲述了基于JSP技术构建的网上订餐系统的设计与实现。所谓的网上订餐系统是通过网站推广互联企业的商品和技术服务,并使客户随时可以了解企业和企业的产品,为客户提供在线服务和订单处理功能。 从长期的战略目标来说,网站不仅是…

ASR 点亮闪光灯和后摄对焦马达

ASR翱捷科技 ASR kernel 5.10 android14 ASR EVB平台 ASR 原理图 闪光灯是gpio控制 1.驱动 路径:asr\kernel\linux\drivers\media\platform\asr-mars11\flash\leds-gpio-flash.c 驱动加载后生成设备节点/sys/class/leds/torch 和/sys/class/leds/flash。 Makefile Kconfig…

Linux中线程的基本概念与线程控制

Linux操作系统中线程 1、进程指的是加载进内存的程序,进程 内核数据结构 进程代码和数据 2、进程在执行ABCD四个函数时是一个单执行流,而如果想让AB函数和CD函数并发执行,我们通常会创建一个子进程,但这意味着需要创建新的进程…

初级数据结构——单向链表

前言 单向链表示最基础的数据结构之一,它也是我们学习开始学习数据结构的第一个必须要掌握的数据结构,学习数据结构一定是由浅到深,所以我们最好是先学习简单的在学习有难度的,因为直接学习难的数据结构很容易劝退,让…

RTMP推流H264和AAC

使用 librtmp 库实现推流h264和aac文件,rtmp服务器使用SRS搭建,拉流端使用VLC。其中用到的h264和aac文件解析部分代码在我其它博客中有写:C/C AAC文件解析-CSDN博客、C/C H264文件解析-CSDN博客。 推流部分源码(C)如下…

中国药品注册审批数据库- 药品注册信息查询与审评进度查询方法

药品的注册、审评审批进度信息是医药研发相关人员每天都会关注的信息,为了保证药品注册申请受理及审评审批进度信息的公开透明,CDE药审中心提供药品不同注册分类序列及药品注册申请受理的审评审批进度信息查询服务。但因CDE官网的改版导致很大一部分人不…

代数插值实验

实验类型:●验证性实验 ○综合性实验 ○设计性实验 实验目的:进一步熟练掌握Lagrange插值算法、Newton插值算法,提高编程能力和解决插值问题的实践技能。 实验报告:根据实验情况和结果撰写并递交实验报告。 实验报告打印和装…

物联网智能技术的深入探讨与案例分析

✅作者简介:2022年博客新星 第八。热爱国学的Java后端开发者,修心和技术同步精进。 🍎个人主页:Java Fans的博客 🍊个人信条:不迁怒,不贰过。小知识,大智慧。 💞当前专栏…

点云配准之点到点,点到面,点到线ICP,NDT算法介绍

点云配准(Point Cloud Registration)即求一个位姿变换 x [ R , t ] \mathbf{x}[\mathbf{R},\mathbf{t}] x[R,t],将源点云 Q { q 1 , ⋯ , q m } Q\{\mathbf{q}_{1},\cdots,\mathbf{q}_{m}\} Q{q1​,⋯,qm​}变换到与目标点云 P { p 1 , ⋯…

Html5详解

目录 一、浏览器相关知识 二、html简介 (一)超文本标记语言 (二)HTML基础结构 (三)HTML概念词汇解释 (四)HTML的语法规则 (五)前端开发工具VS Code与插件 1.VS Code的安装 2.安装插件: 3.通过live Server 小型服务器运行项目 4.其他常见设置 5.在线帮…

实现 think/queue 日志分离

当我们使用think/queue包含了比较多的不同队列,日志会写到runtime/log目录下,合并写入的,不好排查问题,我们遇到一个比较严重的就是用了不同用户来执行,权限冲突了,导致部分队列执行不了. 为了解决以上问题,本来希望通过Log::init设置不同日志路径的,但是本地测试没生效,于是用…

创新不设限,灵码赋新能:通义灵码新功能深度评测

引言 自从2023年通义灵码发布以来,这款基于阿里云通义大模型的AI编码助手便迅速成为了开发者们心中的“明星产品”,受到了广大开发者的关注与好评。它不仅为个人开发者提供了强大的支持,帮助企业团队提升了研发效率,同时也推动了…

道品科技智慧农业中的物联网技术:生产与溯源系统的结合

随着全球人口的不断增长和城市化进程的加快,农业面临着巨大的挑战,包括资源短缺、环境污染和食品安全等问题。为了解决这些问题,智慧农业应运而生,其中物联网(IoT)技术的应用为农业的现代化提供了强有力的支…

【MPC-Simulink】EX03 基于非线性系统线性化模型MPC仿真(MIMO)

【MPC-Simulink】EX03 基于非线性系统线性化模型MPC仿真(MIMO) 参考 Matlab 官网提供的 Model Predictive Control Toolbox - Getting Started Guide,以零初始状态条件下的非线性系统在线性化后得到的多输入多输出(MIMO&#xff…

期权开户难不难?期权开户成功后当天是否能交易

期权开户难不难?这取决于投资者的准备情况和所选的开户途径。对于满足一定资金和经验要求的投资者来说,通过正规期货公司或期权交易平台进行开户,虽然流程相对复杂,但只要遵循步骤,仍然可以顺利完成,下文为…

沈阳乐晟睿浩科技有限公司引领新潮流

在当今数字化浪潮汹涌的时代,电子商务以其独特的魅力和无限潜力,正深刻改变着人们的消费习惯与商业模式。沈阳乐晟睿浩科技有限公司(以下简称“乐晟睿浩”),作为电商领域的一颗璀璨新星,凭借其深厚的技术实…

【一步步开发AI运动小程序】二十一、如果将AI运动项目配置持久化到后端?

**说明:**本文所涉及的AI运动识别、计时、计数能力,都是基于云智「Ai运动识别引擎」实现。云智「Ai运动识别」插件识别引擎,可以为您的小程序或Uni APP赋于原生、本地、广覆盖、高性能的人体识别、姿态识别、10余种常见的运动计时、计数识别及…

Python栈--深度优先搜索(迷宫问题)

给一个二维列表,表示迷宫(0表示给出算法,求通道,1表示围墙)。 给出算法,求一条走出迷宫的路径。 maze [ [1, 1, 1, 1, 1, 1, 1, 1, 1, 1], [1, 0, 0, 1, 0, 0, 0, 1, 0, 1], [1, 0, 0, 1, 0, 0, 0, 1, 0, 1], […

安卓主板_基于联发科MTK MT8788平台平板电脑方案_安卓核心板开发板定制

联发科MT8788安卓核心板平台介绍: MTK8788设备具有集成的蓝牙、fm、wlan和gps模块,是一个高度集成的基带平台,包括调制解调器和应用处理子系统,启用LTE/LTE-A和C2K智能设备应用程序。该芯片集成了工作在2.0GHz的ARM Cortex-A73、最…