【Java 网络编程】TCP 传输机制 ( 数据拆分 | 排序 | 顺序发送 | 顺序组装 | 超时重发 )

简介: 【Java 网络编程】TCP 传输机制 ( 数据拆分 | 排序 | 顺序发送 | 顺序组装 | 超时重发 )

文章目录

I TCP 传输过程

II TCP 传输示例

III TCP 传输特殊情况处理



I TCP 传输过程


1. TCP 传输过程 : 排序 , 顺序发送 , 顺序组装 ;


① 排序 : TCP 发送数据时 , 会将数据拆分成不同的片段 , 并对这些片段进行排序 ;

② 顺序发送 : 将排序好的数据片段顺序发送 ;

③ 顺序组装 : 在接收端按照顺序将数据片段组装成原数据 ;

2. 超时重发机制 : 如果某个数据片没有到达 , 或者送达时间超时 , 接收方会将相关信息反馈给发送方 , 发送方需要将该数据片重新发送 ;


3. 拆分数据作用 ( 节省流量 ) : 当数据没有送达或者超时 , 是需要重新发送数据的 , 如果不拆分数据 , 将一整包数据整体发送 , 如果发送失败 , 需要重新发送整个数据 , 这样就非常浪费流量 ;


4. 数据重发机制 : 服务器端收到客户端发送的数据时 , 其会定时向客户端发送服务器端已经收到的数据 , 如果客户端没有收到服务器端反馈的某条数据已经送达 , 客户端就会认为该数据没有送达 , 客户端重新将该数据重新发送一遍 ;




II TCP 传输示例


1. A 向 B 发送 5 个数据包 :


① 发送第一帧数据 ( 完成 ) : 首先将第一帧数据发送给 B , B 收到 1 数据 , 将收到 1 数据反馈给 A , 表明已经收到了第一帧数据 ;

② 发送第二帧数据 ( 反馈信息未送达 ) : 发送第二帧数据 , 接收方收到了 2 数据 , 但是反馈信息没能发送给 A ;

③ 发送第三帧数据 ( 没有送达 B ) : 发送的第三帧数据没有发送到 B , 中途丢包了 ;

④ 发送第四帧数据 ( 反馈信息未送达 ) : 第四帧数据送达 B , 但是 B 的反馈信息没有送达 A ;

⑤ 发送第五帧数据 ( 完成 ) : 第五帧数据发送到 B , B 的反馈信息也送到了 A ;

2. 重发数据 : 其中第三帧数据没有送达 , 时钟超时 , B 将相关信息发送到 A , A 重发第三帧数据 ;


image.png




III TCP 传输特殊情况处理


1. 发送过程中没有按顺序到达 : 被拆分的数据包是按照排好的顺序发送到接收端的 , 但是由于网络原因 , 可能到达接收方不是原来的顺序 , 接收方会重新进行排序 ;


2. 丢包情况处理 : 如果发送端在超时时间内没有收到接收端的某个包的反馈信息 , 就会认为该包没有送达 , 在超时后 , 会重新发送该包数据 ;


3. 连接断开情况处理 : 如果连接传输中途断开 , 需要进行重连 , 重连后再次发送数据 ;


目录
相关文章
|
2月前
|
Java API 开发工具
【Azure Developer】Java代码实现获取Azure 资源的指标数据却报错 "invalid time interval input"
在使用 Java 调用虚拟机 API 获取指标数据时,因本地时区设置非 UTC,导致时间格式解析错误。解决方法是在代码中手动指定时区为 UTC,使用 `ZoneOffset.ofHours(0)` 并结合 `withOffsetSameInstant` 方法进行时区转换,从而避免因时区差异引发的时间格式问题。
164 3
|
3月前
|
JSON 移动开发 网络协议
Java网络编程:Socket通信与HTTP客户端
本文全面讲解Java网络编程,涵盖TCP与UDP协议区别、Socket编程、HTTP客户端开发及实战案例,助你掌握实时通信、文件传输、聊天应用等场景,附性能优化与面试高频问题解析。
|
3月前
|
数据采集 JSON Java
Java爬虫获取1688店铺所有商品接口数据实战指南
本文介绍如何使用Java爬虫技术高效获取1688店铺商品信息,涵盖环境搭建、API调用、签名生成及数据抓取全流程,并附完整代码示例,助力市场分析与选品决策。
|
3月前
|
数据采集 存储 前端开发
Java爬虫性能优化:多线程抓取JSP动态数据实践
Java爬虫性能优化:多线程抓取JSP动态数据实践
|
23天前
|
JSON 网络协议 安全
【Java】(10)进程与线程的关系、Tread类;讲解基本线程安全、网络编程内容;JSON序列化与反序列化
几乎所有的操作系统都支持进程的概念,进程是处于运行过程中的程序,并且具有一定的独立功能,进程是系统进行资源分配和调度的一个独立单位一般而言,进程包含如下三个特征。独立性动态性并发性。
88 1
|
23天前
|
JSON 网络协议 安全
【Java基础】(1)进程与线程的关系、Tread类;讲解基本线程安全、网络编程内容;JSON序列化与反序列化
几乎所有的操作系统都支持进程的概念,进程是处于运行过程中的程序,并且具有一定的独立功能,进程是系统进行资源分配和调度的一个独立单位一般而言,进程包含如下三个特征。独立性动态性并发性。
91 2
|
2月前
|
算法 Java
Java多线程编程:实现线程间数据共享机制
以上就是Java中几种主要处理多线程序列化资源以及协调各自独立运行但需相互配合以完成任务threads 的技术手段与策略。正确应用上述技术将大大增强你程序稳定性与效率同时也降低bug出现率因此深刻理解每项技术背后理论至关重要.
155 16
|
26天前
|
机器学习/深度学习 分布式计算 Java
Java与图神经网络:构建企业级知识图谱与智能推理系统
图神经网络(GNN)作为处理非欧几里得数据的前沿技术,正成为企业知识管理和智能推理的核心引擎。本文深入探讨如何在Java生态中构建基于GNN的知识图谱系统,涵盖从图数据建模、GNN模型集成、分布式图计算到实时推理的全流程。通过具体的代码实现和架构设计,展示如何将先进的图神经网络技术融入传统Java企业应用,为构建下一代智能决策系统提供完整解决方案。
208 0
|
7月前
|
自然语言处理 Java 关系型数据库
Java|小数据量场景的模糊搜索体验优化
在小数据量场景下,如何优化模糊搜索体验?本文分享一个简单实用的方案,虽然有点“土”,但效果还不错。
119 0
|
传感器 分布式计算 安全
Java 大视界 -- Java 大数据在智能安防入侵检测系统中的多源数据融合与分析技术(171)
本文围绕 Java 大数据在智能安防入侵检测系统中的应用展开,剖析系统现状与挑战,阐释多源数据融合及分析技术,结合案例与代码给出实操方案,提升入侵检测效能。
下一篇
开通oss服务