-
为什么快速重传是选择3次ACK?
- 个人理解:首先网络中的丢包,乱序以及网路故障都会让服务器端发回duplicated ACK,表示有一个包一直未收到。快速重传是通过3次ACK来区分乱序,丢包和网路拥塞的情况,是基于实践经验得到的,所以说这种判断方式不一定准确,只是"大概率"可以解决问题。
- 在timeout期间,如果并没有收到ACK,就直接超时重传并执行慢开始
- 在timeout期间,如果收到的duplicated ACK小于等于两次,那么很可能是因为包到达的顺序是乱序:包A后边的包先到了,但是A还没有到达,所以服务器端就会请求包A,由于网络中没有别的问题,所以服务器稍微等了一会儿(一般小于等于两次),包A就到了,如果是这种情况,那么我们不需要做任何改动,因为乱序问题服务器端TCP会处理
- 在timeout期间,如果收到的duplicated ACK达到3次,那么很可能是因为丢包或者网络拥塞导致包无法发送到服务器端:
- 如果是网络拥塞,那么我们直接降低网络流量是合理的
- 如果是因为偶然的错误某个包丢了,我们就慢开始从1开始发送网络流量,就很影响传输效率
- 对于上述情况出现概率都是50%,我们采用一种稍微乐观的态度(毕竟3次都能传回来,应该心态好点),将上述情况中和一下,也不重新慢开始,也不能什么都不做,当看到3次 duplicated ACK,我们快速重传一次(不等重传计时器),并使用快恢复策略,即拥塞窗口减半,阈值等于拥塞窗口。
-
个人理解,欢迎指正!
学习笔记18——个人理解为什么快速重传是3次ACK
热烈小狗2024-01-12 10:41
相关推荐
QT 小鲜肉8 小时前
【Linux命令大全】001.文件管理之git命令(实操篇)半夏知半秋8 小时前
docker常用指令整理LXS_3579 小时前
Day 18 C++提高 之 STL常用容器(string、vector、deque)蒸蒸yyyyzwd9 小时前
网络编程——threadpool.h学习笔记浪子不回头4159 小时前
SGLang学习笔记小波小波轩然大波9 小时前
openstack总结百***78759 小时前
Step-Audio-2 轻量化接入全流程详解我叫逢9 小时前
一键去水印实战已上线!心得~deng-c-f10 小时前
Linux C/C++ 学习日记(53):原子操作(二):实现shared_ptr