八股训练营第 7 天 | TCP连接如何确保可靠性?拥塞控制是怎么实现的?TCP流量控制是怎么实现的?UDP怎么实现可靠传输?

TCP连接如何确保可靠性

通过差错控制、超时重传、拥塞控制、流量控制等。

  • 序列号:TCP 报文头部有序列号字段,保证报文的顺序性。
  • 差错校验:TCP 通过校验和来检验数据包传输时有没有发生错误,如果发生,会丢弃该数据包,并要求发送方重传。
  • ACK 确认:接收方收到报文后会发送 ACK 确认给发送方。如果发送方没有收到,则会重传。
  • 超时重传:发送方发送报文后会启动一个计时器。如果计时器介绍后未收到接收方确认,则重传。
  • 拥塞控制:发送方会根据网络状况动态调节发送窗口,以避免发生网络拥塞。
  • 流量控制:发送方会根据接收方接收窗口大小调节发送窗口大小,避免发送太多接收方接收不过来的情况。

既然提到了拥塞控制,那你能说说说拥塞控制是怎么实现的嘛

拥塞控制就是根据网络状况,动态调节发送方的数据发送速率,以避免出现网络过载。

主要包括

  1. 慢启动:一开始发送方的发送窗口为 1,然后再收到接收方的 ACK 确认后,按 2、4、8 的指数速度增长。一开始设置较低的速率有助于在网络连接初期避免发送网络拥塞。

  2. 拥塞避免:当发送窗口大小达到慢启动门限阈值时,采用拥塞避免策略。此时发送窗口大小不再按照指数增长,而是线性增长。

    当发生网络拥塞时,发送窗口大小降为 1,慢启动门限阈值降为当前拥塞窗口的一半。之后再进行慢启动。

  3. 快重传:当收到连续多个接收方的对同一消息的确认后,发送方立即重传该报文,无需等待重传计时器超时。这有助于快速从网络拥塞中恢复。

  4. 快恢复:当快重传后,发送窗口无需降为 1,发送窗口和慢启动门限都只需降低到发生拥塞时拥塞窗口的一半。之后执行拥塞避免算法。

TCP流量控制是怎么实现的

流量控制就是让发送方发送速率不要太快,避免出现接收方来不及接收的情况。是通过滑动窗口机制实现的。

  • 接收方 ACK 确认的报文中,会有窗口字段的数据,以告诉发送方自己接收窗口的大小。
  • 发送方会将自己的发送窗口大小设置为接收窗口的大小。
  • 接收方如果缓冲区可用空间不多,就将接收窗口的大小设小些,以避免发送方发送速率过快导致缓冲区溢出。
  • 当接收方告知接收窗口为 0 后,发送方会在等待一段时间后发送 0 报文探测器,以检查接收方有没有增大接受窗口大小。从而避免死锁。

UDP怎么实现可靠传输

UDP 实现可靠传输不能在传输层实现,只能在应用层实现。

可仿照 TCP 的实现方式,增加超时重传机制和报文的序列号。

  1. 在 UDP 报文增加一个首部,记录报文的序列号和时间戳,时间戳用于计算 RTT 从而计算出 RTO。发送报文后,采用停-等机制等待接收方的确认。若在 1 RTO 时间未等到,则超时重传,同时将 RTO * 2。
  2. 接收方收到报文后,从首部提取出序列号和时间戳。放入对已收到报文的确认序列号发送给发送方。然后对收到的报文的序列号进行排序,去除重复的报文。

RTT(Round Trip Time) 和 RTO(Retransmission Time Out) 是 TCP 协议中两个重要的概念。

RTT 是指一个数据包从发送端发送到接收端并返回发送端的总时间,而 RTO 是指在发送数据包后等待确认的超时时间。

相关推荐
木斯佳8 小时前
前端八股文面经大全:字节跳动前端一面·深度解析(Plus Ultra版)(2026-03-30)·面经深度解析
前端·设计模式·八股·光栅化
wxm6319 小时前
TCP监听--监听指定IP的端口号
java·网络·tcp/ip
一个有温度的技术博主9 小时前
网安实验系列三:信息收集之Ip收集
网络·网络协议·tcp/ip
Hello_Embed9 小时前
嵌入式上位机开发入门(五):UDP 编程 —— Server 端实现
笔记·单片机·网络协议·udp·嵌入式
松小白song11 小时前
Modbus RTU/TCP 的区别
网络·网络协议·tcp/ip
Mountain and sea12 小时前
从一次通讯中断事故说起:Modbus TCP 调试实战与避坑指南
网络·网络协议·tcp/ip·工业机器人
三三有猫1 天前
代理IP:按流量还是按IP/时长计费更划算?
网络·网络协议·tcp/ip
未来转换1 天前
计算机网络基础之IP地址详解
tcp/ip·计算机网络·php
芦芭荞1 天前
QT之TCP/IP通讯
开发语言·qt·tcp/ip
李彦亮老师(本人)1 天前
网络安全基础:TCP/IP 协议栈安全分析与防护
tcp/ip·安全·web安全