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

相关推荐
wang09077 分钟前
常用网络工具分析(ping,tcpdump等)
网络·tcpdump
真正的醒悟35 分钟前
H3C交换机&路由器&防火墙FTP/TFTP服务器搭建。
服务器·网络·智能路由器
春生黎至10051 小时前
路由基本配置
网络·智能路由器
不修×蝙蝠1 小时前
Tomcat理论(Ⅰ)
java·服务器·java-ee·tomcat
望获linux1 小时前
如何在望获实时 Linux & 京博航友善 NanoPC-T6 上部署 Docker
linux·运维·服务器·docker·eureka·开源软件
wangchen_01 小时前
linux编译器和自动化构建工具(gcc与Makeile)
linux·运维·服务器
DC_BLOG1 小时前
Linux-Ansible命令
linux·运维·服务器·ansible
贩卖纯净水.2 小时前
REACT学习DAY02(恨连接不上服务器)
服务器·学习·react.js
Hacker_LaoYi2 小时前
x安全服务 y安全体系 z网络安全模型 网络安全体系设计
网络·安全·web安全
一ge科研小菜鸡2 小时前
DeepSeek 与网络安全:AI 在网络安全领域的应用与挑战
网络