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连接的可靠性

相关推荐
Bug退退退1231 小时前
Java 网络流式编程
java·服务器·spring·sse
QotomPC1 小时前
软件定义的理想硬件平台:Qotom Q30900SE/UE系列在AIO服务器与边缘网关中的实践
运维·服务器
望获linux1 小时前
【实时Linux实战系列】实时系统的可观测性:Prometheus 与 Grafana 集成
大数据·linux·服务器·开发语言·网络·操作系统
捷智算云服务1 小时前
H200服务器维修服务体系构建:捷智算的全链条保障方案
运维·服务器
hweiyu001 小时前
Linux 命令:mount
linux·运维·服务器
AI视觉网奇1 小时前
redis 配置学习笔记
linux·服务器
红尘客栈22 小时前
K8s-kubeadmin 1.28安装
java·网络·kubernetes
hello_2502 小时前
动手模拟k8s网络-vxlan模式
网络·容器·kubernetes
我梦之63 小时前
libevent输出缓存区的数据
服务器·网络·c++·缓存
春生野草3 小时前
MobaXterm远程连接云服务器及配置jdk、Tomcat环境
运维·服务器