被问了一个奇怪的问题:TCP 流量控制和拥塞控制的区别?

TCP 流量控制和拥塞控制的区别?

今天,被问了一个这样的奇怪的问题:TCP 流量控制和拥塞控制的区别?

两者的控制层面不一样,TCP 流量控制是端对端的控制,拥塞控制是网络层面的控制

  • 流量控制:这是一个端对端的控制,主要控制避免发送方发送过多的数据给接收方,以至于接收不过来的情况,核心是通过滑动窗口的机制,接收方在 ACK 报文中告诉发送方自己的接收窗口的大小,也就是可接受的数据量,让发送方不要发送过多的数据
  • 拥塞控制:这是网络层面的控制,主要目的是防止过的的数据包同时在网络上传输,以至于网络拥塞。主要是通过慢启动,拥塞避免,拥塞发生,超时重传和快速重传和快启动等算法实现的

所以,流量控制是为了保护接收方不被数据淹没,拥塞控制是为了保护网络不被拥塞

流量窗口是怎么设计的?解决什么问题?

发送方和接收方在各自的内核中都有一个缓冲区,各自的缓冲区中又都有一个窗口,发送方缓冲区的窗口大小表示可以发送的最大数据量,接收方缓冲区的窗口大小表示可以接受的最大数据量

  • 发送方有了发送窗口后,就可以不用等待已发送数据的确认报文,就可以继续发送下一条报文,提高发送的效率
  • 接收方有了发送窗口后,就可以告诉发送方自己可接受的数据量,避免发送方数据过快,实现流量控制
相关推荐
landonVM8 分钟前
Linux 上搭建 Web 服务器
linux·服务器·前端
学习中的DGR8 分钟前
[极客大挑战 2019]Http 1 新手解题过程
网络·python·网络协议·安全·http
云游云记17 分钟前
nesbot/carbon 常用功能总结
linux·运维·服务器
landonVM35 分钟前
Linux 下的高效压缩工具 Zstandard
linux·运维·服务器
遇见火星36 分钟前
服务器运维操作命令速查手册
运维·服务器
EmbedLinX1 小时前
Linux之内存管理
linux·服务器·c语言·c++
2301_792580001 小时前
xuepso
java·服务器·前端
Nightwish51 小时前
Linux随记(二十八)
linux·运维·服务器
Zach_yuan1 小时前
Socket 编程基础
linux·服务器
女王大人万岁1 小时前
Go标准库 io与os库详解
服务器·开发语言·后端·golang