tcp的可靠性

1.应答确认

TCP 发送的报文段是交给 IP 层传送的。但IP 层只能提供尽最大努力的服务,也就是说,TCP 下面的网络所提供的是不可靠的传输。因此,TCP 必须采用适当的措施才能使两个运输层之间的通信变得可靠。 TCP 的可靠传输是通过使用应答确认和超时重传来完成

2.超时重传机制

无差错时,数据的交互:

有差错数据的交互流程:

3.乱序重排,去重

接收方接收到数据,很大可能都是乱序的,因为我们发送的数据都是带有报头的(详见网络应用程序通信流程图),根据TCP报头中的序号进行乱序重排即可.

如果由于网络延迟导致数据重发,最终接收方收到了多份的数据,同理,根据报头中的序号进行去重即可。

TCP传输是可靠的,首先,TCP协议采用发送应答机制,即发送端发送的每个TCP报文段都必须得到接收方的应答,才认为这个TCP报文段传输成功.

其次,TCP协议采用超时重传机制,发送端在发送一个TCP报文段之后启动定时器,如果在定时时间内未收到应答,它将重发该报文段,最后,因为TCP报文段最终是以IP数据报发送的,而IP数据报到达接收端可能乱序,重复,所以TCP协议还会对接收到的TCP报文段重排,整理,再交付给应用层。

UDP协议则和IP协议一样,提供不可靠服务.它们都需要上层协议来处理数据确认和超时重传(现在理解IP协议为什么是不可靠的了吧?)

应答确认,超时重传,乱序重排,去重最终保证了tcp连接的可靠性

相关推荐
韩楚风几秒前
【linux 多进程并发】linux进程状态与生命周期各阶段转换,进程状态查看分析,助力高性能优化
linux·服务器·性能优化·架构·gnu
陈苏同学4 分钟前
4. 将pycharm本地项目同步到(Linux)服务器上——深度学习·科研实践·从0到1
linux·服务器·ide·人工智能·python·深度学习·pycharm
Pythonliu726 分钟前
茴香豆 + Qwen-7B-Chat-Int8
linux·运维·服务器
我是哈哈hh42 分钟前
专题十_穷举vs暴搜vs深搜vs回溯vs剪枝_二叉树的深度优先搜索_算法专题详细总结
服务器·数据结构·c++·算法·机器学习·深度优先·剪枝
郭二哈1 小时前
C++——模板进阶、继承
java·服务器·c++
狼头长啸李树身1 小时前
眼儿媚·秋雨绵绵窗暗暗
大数据·网络·服务发现·媒体
挥剑决浮云 -1 小时前
Linux 之 安装软件、GCC编译器、Linux 操作系统基础
linux·服务器·c语言·c++·经验分享·笔记
立秋67891 小时前
Python的defaultdict详解
服务器·windows·python
SizeTheMoment2 小时前
初识HTTP协议
网络·网络协议·http
Lansonli2 小时前
云原生(四十一) | 阿里云ECS服务器介绍
服务器·阿里云·云原生