<JavaEE> TCP 的通信机制(一) -- 确认应答 和 超时重传

news/2024/5/17 15:50:59 标签: 网络协议, tcp, java-ee

目录

TCP的通信机制的核心特性

一、确认应答

1)什么是确认应答?

2)如何“确认”?

3)如何“应答”?

二、超时重传

1)丢包的概念

2)什么是超时重传?

3)两种触发超时重传的情况

4)等待多久算超时?

5)重复的数据如何处理?


TCP的通信机制的核心特性

TCP的通信机制最核心的特性是可靠传输。
TCP至少通过以下机制来保证传输的可靠性,在保证可靠性的同时也采取一些机制来提升传输效率
<1> 确认应答<6> 阻塞控制
<2> 超时重传<7> 延时应答
<3> 连接管理<8> 捎带应答
<4> 滑动窗口<9> 面向字节流
<5> 流量控制<10> 异常情况处理

一、确认应答

确认应答是TCP最核心的机制,以确认应答为核心,辅助其他机制,使得TCP完成了可靠传输。

1)什么是确认应答?

发送端将数据发送给接收端,接收端成功收到数据后(即确认),会给发送端返回一个应答报文(即应答)。应答报文的作用是让发送端知道数据是否成功传输。

2)如何“确认”?

<1> 校验和:用于确认接收的数据是否在传输的过程中发生了改变。常使用CRC或MD5等校验方式。
<2> 序号:序号是一系列具有大小关系的整数,描述了数据的先后顺序。接收端需要确认收到的数据包的序号是否符合数据序列。

3)如何“应答”?

<1> “ACK”标志位:使用应答报文进行应答,应答报文被称为ACK(Acknowledge),如果该数据包是应答报文,标志位“ACK”将为1,否则为0。
<2> 确认序号:应答报文中将包含“确认序号”。确认序号的作用在于告知发送端,接收端已经收到了哪些数据和接下来需要发送端发送的下一系列数据的起始位置。

二、超时重传

1)丢包的概念

丢包是指,数据包在网络传输的过程中没有到达接收端;或者虽然到达了接收端,却因为传输过程中的干扰使得接收到的数据是错误的数据。

2)什么是超时重传?

超时重传是指,在发送端发送数据后没有接收到接收端的应答报文,在等待一段时间后(即超时)就会重新发送该数据(重传)。
重传可以大幅提升数据传输的可靠性。

3)两种触发超时重传的情况

上述两种情况,归根结底是由于发送端没有收到应答报文才触发了超时重传。

4)等待多久算超时?

初始等待时间,不同的系统设定的时间是不一样的,而且这个时间是可以配置的。
TCP为了保证无论在任何环境下都能较高性能的通信,会动态计算最大超时时间。每一次超时后,等待的时间都会变长。

5)重复的数据如何处理?

在上述情况2,返回的ACK丢包的情况下。接收端会多次收到重复的数据。
TCP通过“序号”这一属性来识别哪些包是重复的包,已经接收过的包的“序号”会被存放在“接收缓冲区”中,如果接收端发现当前发送的数据已经存在,会直接丢弃这些数据包。
“接收缓冲区”不仅能进行去重,还能进行重排序,确保读取的顺序和发送的顺序是一致的。

阅读指针 -> 《 TCP 的通信机制(二) -- 连接管理(三次握手和四次挥手) 》

链接生成中...........


http://www.niftyadmin.cn/n/5288567.html

相关文章

【机电、机器人方向会议征稿|不限专业|见刊快】2024年机械、 图像与机器人国际会议(IACMIR 2024)

【机电、机器人方向会议征稿|不限专业|见刊快】2024年机械、 图像与机器人国际会议&#xff08;IACMIR 2024&#xff09; 2024 International Academic Conference on Machinery, Images, and Robotics 会议将聚焦“机械、成像和机器人”相关的最新研究领域&#xff0c;为国内…

学习笔记13——Spring整合Mybatis、junit、AOP、事务

学习笔记系列开头惯例发布一些寻亲消息 链接&#xff1a;https://baobeihuijia.com/bbhj/ Mybatis - Spring&#xff08;使用第三方包new一个对象bean&#xff09; 原始的Mybatis与数据库交互【通过sqlmapconfig来配置和连接】 初始化SqlSessionFactory获得连接获取数据层接口…

nas卡住问题

分析 尝试重新挂载还是无法解决问题&#xff0c;重启后回复正常&#xff0c;重启后收集sosreport。 查看了sosreport/var/log/message&#xff0c;在问题出现的时间点前后没有发现NFS相关的报错信息&#xff08;见图&#xff09;&#xff0c;由此推测NFS连接并未直接断开且本…

4、GitHub操作

GitHub 1. 创建远程仓库2. 远程仓库操作1. 创建远程仓库别名2. 推送本地分支到远程仓库3. 拉取远程仓库到本地库4. 克隆远程仓库到本地5. 邀请加入团队 3.跨团队协作4. SSH免密登录 GitHub官网: https://github.com/ 1. 创建远程仓库 远程库最好和本地库的名字一致。 Public&a…

智能优化算法应用:基于鱼鹰算法3D无线传感器网络(WSN)覆盖优化 - 附代码

智能优化算法应用&#xff1a;基于鱼鹰算法3D无线传感器网络(WSN)覆盖优化 - 附代码 文章目录 智能优化算法应用&#xff1a;基于鱼鹰算法3D无线传感器网络(WSN)覆盖优化 - 附代码1.无线传感网络节点模型2.覆盖数学模型及分析3.鱼鹰算法4.实验参数设定5.算法结果6.参考文献7.MA…

数据库的连接池详解

什么是数据库连接池&#xff1f; 数据库连接池是一种管理和维护数据库连接的机制&#xff0c;用于提高数据库访问的性能和效率。连接池通过在应用程序启动时创建一组数据库连接&#xff0c;并在需要时将这些连接分配给应用程序&#xff0c;然后在不再需要时将其返回到池中。这…

odoo17核心概念view7——listview总体框架分析

这是view系列的第七篇文章&#xff0c;今天主要介绍我们最常用的list视图。 1、先看list_view,这是主文件 /** odoo-module */import { registry } from "web/core/registry"; import { RelationalModel } from "web/model/relational_model/relational_mode…

【流复制环境PostgreSQL-14.1到PostgreSQL-16.1大版本升级】

PostgreSQL大版本会定期添加新特性&#xff0c;这些新特性通常会改变系统表的布局&#xff0c;但内部数据存储格式很少改变。pg_upgrade通过创建新的系统表和重用旧的用户数据文件来执行快速升级。 pg_upgrade升级主要有三种用法&#xff1a; 1、使用pg_upgrade拷贝升级。 2、…