SRT拥塞控制分析

一 变量解释

  1. m_LastRCTime:这个变量通常用来记录最后一次接收到数据包的时间戳。它用于计算往返时间(RTT),即数据包从发送端发送到接收端,再从接收端返回确认(ACK)的时间。这个时间戳对于拥塞控制和网络状况的评估非常重要。
  2. m_iRCInterval:这个变量可能指的是接收端发送ACK数据包的时间间隔。它决定了ACK数据包的发送频率,从而影响发送端对网络状况的感知速度。
  3. m_bSlowStart:这是一个布尔变量,用于指示当前是否处于慢启动阶段。在慢启动阶段,发送端会逐渐增加发送速率,直到网络出现丢包,这时会触发拥塞控制机制,减少发送速率。
  4. m_iDeliveryRate:这个变量表示接收端的数据包到达率,即每秒接收到的数据包数量。它反映了接收端每秒能够接收的数据包的数量,是衡量网络接收性能的一个重要参数。
  5. m_dCWndSize:拥塞窗口的大小,用于控制发送端在网络中可以发送的最大数据量,而不会导致网络拥塞或丢包。这个值是动态调整的,以适应网络条件的变化。
  6. m_dPktSndPeriod:数据包发送周期,用于控制发送数据包的频率。这个值通常与拥塞窗口大小和往返时间(RTT)一起使用,来决定数据包的发送速率。
  7. m_bLoss:这个布尔变量可能用于指示是否检测到丢包。如果检测到丢包,发送端可能需要触发重传机制或者调整发送策略。
  8. m_maxSR:这个变量可能与SRT的最大传输速率有关,它限制了发送端可以发送数据的最大速率。
  9. m_dLastDecPeriod:这个变量可能记录了最后一次降低发送速率的时间间隔。在拥塞控制中,如果网络出现丢包,发送端可能会增加数据包发送间隔,以减少网络拥塞。
  10. m_iAvgNAKNum:平均NACK(负确认)数量,用于统计在一定时间内接收端请求重传的数据包的平均数量。这个值可以帮助发送端评估网络丢包情况。
  11. m_iNAKCount:NACK计数器,用于记录在一定时间内接收端发送的NACK数量。这个值反映了接收端缺失数据包的数量。
  12. m_iDecCount:这个变量可能与拥塞控制中的减速事件计数有关,用于记录在一定时间内发送端降低发送速率的次数。
  13. m_iLastDecSeq:记录最后一次降低发送速率时的数据包序列号。这个值用于跟踪拥塞控制事件和调整发送策略。
  14. m_iDecRandom:这个变量可能与拥塞控制中的随机性因素有关,用于在拥塞事件发生时引入随机性,以避免多个发送端同时降低速率导致的网络振荡

二 拥塞控制逻辑分析

onACK()

onLossReport()

onRTO()

onACK()

{

const steady_clock::time_point currtime = steady_clock::now();

if (count_microseconds(currtime - m_LastRCTime) < m_iRCInterval)

return;

m_LastRCTime = currtime;

//上面更新拥塞调控时间点,调整间隔为10ms

if (m_bSlowStart) //慢启动过程

{

m_dCWndSize += CSeqNo::seqlen(m_iLastAck, ack); //拥塞窗口 += 本次ack的数据量

m_iLastAck = ack;

if (m_dCWndSize > m_dMaxCWndSize) //达到拥塞窗口最大值

{

m_bSlowStart = false; //慢启动结束

if (m_parent->deliveryRate() > 0) //发送速率根据对端ack的数据计算出来的,

//对端会统计和数据接收速度

{

m_dPktSndPeriod = 1000000.0 / m_parent->deliveryRate();

HLOGC(cclog.Debug, log << "FileCC: UPD (slowstart:ENDED) wndsize="

<< m_dCWndSize << "/" << m_dMaxCWndSize

<< " sndperiod=" << m_dPktSndPeriod << "us = 1M/("

<< m_parent->deliveryRate() << " pkts/s)");

}

else

{

m_dPktSndPeriod = m_dCWndSize / (m_parent->SRTT() + m_iRCInterval); //发包间隔计算,倒数就是带宽了。

HLOGC(cclog.Debug, log << "FileCC: UPD (slowstart:ENDED) wndsize="

<< m_dCWndSize << "/" << m_dMaxCWndSize

<< " sndperiod=" << m_dPktSndPeriod << "us = wndsize/(RTT+RCIV) RTT="

<< m_parent->SRTT() << " RCIV=" << m_iRCInterval);

}

}

else

{

HLOGC(cclog.Debug, log << "FileCC: UPD (slowstart:KEPT) wndsize="

<< m_dCWndSize << "/" << m_dMaxCWndSize

<< " sndperiod=" << m_dPktSndPeriod << "us");

}

}

else //非慢启动阶段

{

//m_iRCInterval ACK间隔

m_dCWndSize = m_parent->deliveryRate() / 1000000.0 (m_parent->SRTT() + m_iRCInterval) + 16;//16为增益,拥塞窗口 = 发送速率 / 1000000rt**t + 1**0 + 1**6

HLOGC(cclog.Debug, log << "FileCC: UPD (speed mode) wndsize="

<< m_dCWndSize << "/" << m_dMaxCWndSize << " RTT = " << m_parent->SRTT()

<< " sndperiod=" << m_dPktSndPeriod << "us. deliverRate = "

<< m_parent->deliveryRate() << " pkts/s)");

}

//非慢启动阶段

}

onLossReport

{

2%以下丢包,不处理

onRTO

{

发生在慢启动阶段,和前面丢包处理一样,重新计算发送周期,如果不是慢启动阶段,暂时不处理, 因为会有丢包,这样上面onLossReport直接处理了。

}

}

相关推荐
编程修仙8 分钟前
Vector和ArrayList的比较
java·开发语言
傻啦嘿哟43 分钟前
Python实现基础到高级:语音验证码技术详解
开发语言·python
转测试啦转测试啦1 小时前
Redis哨兵(sentinel)
redis·sentinel·php
Hacker_xingchen1 小时前
一些常见网络安全术语
网络·安全·web安全
《源码好优多》1 小时前
基于Java Springboot图书馆管理系统
java·开发语言·spring boot
查理不安生1 小时前
【Mac】未能完成该操作 Unable to locate a Java Runtime
java·开发语言·macos
SoraLuna1 小时前
「Mac玩转仓颉内测版19」PTA刷题篇10 - L1-010 比较大小
开发语言·算法·macos·cangjie
夏天匆匆2过1 小时前
网络传输:网卡、IP、网关、子网掩码、MAC、ARP、路由器、NAT、交换机
linux·网络·网络协议·tcp/ip
弥琉撒到我2 小时前
docker对其他中间件镜像拉取多个服务器部署
开发语言·后端·ruby
chirrupy_hamal2 小时前
网络基础 - NAT 篇
网络