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直接处理了。

}

}

相关推荐
暴走的YH9 分钟前
【网络协议】三次握手与四次挥手
网络·网络协议
The Future is mine11 分钟前
Python计算经纬度两点之间距离
开发语言·python
yuzhangfeng12 分钟前
【云计算物理网络】数据中心网络架构设计
网络·云计算
Enti7c12 分钟前
HTML5和CSS3的一些特性
开发语言·css3
爱吃巧克力的程序媛19 分钟前
在 Qt 创建项目时,Qt Quick Application (Compat) 和 Qt Quick Application
开发语言·qt
zhu12893035561 小时前
网络安全的重要性与防护措施
网络·安全·web安全
独好紫罗兰1 小时前
洛谷题单3-P5719 【深基4.例3】分类平均-python-流程图重构
开发语言·python·算法
网络研究院1 小时前
ChatGPT 的新图像生成器非常擅长伪造收据
网络·人工智能·安全·chatgpt·风险·技术·欺诈
篝火悟者1 小时前
自学-C语言-基础-数组、函数、指针、结构体和共同体、文件
c语言·开发语言
genispan2 小时前
QT/C++ 多线程并发下载实践
开发语言·c++·qt