webrtc QOS之丢包率 环路延时计算
以PeerA端为例,PeerA想要知道:
1、PeerA发送给PeerB的RTP报文的丢包率和环路延时
2、PeerB发送给PeerA的RTP报文的丢包率。
一、丢包率计算原理
1、peerA统计PeerB发送给PeerA的丢包率
PeerA接收报文的丢包率,可以通过判断收到报文的RTP***的连续性计算。
在webrtc里面函数实现如下:
->RTCPSender::SendRTCP
->RTCPSender::SendCompoundRTCP
->RTCPSender::BuildRR
->RTCPSender::CreateReportBlocks
->ReceiveStatisticsImpl::RtcpReportBlocks
->StreamStatisticianImpl::GetStatistics
->StreamStatisticianImpl::CalculateRtcpStatistics
2、PeerA发送给PeerB的RTP报文的丢包率
PeerB根据接收到的RTP报文***的连续性计算出来,然后PeerB通过RTCP的RR报文,把丢包率信息告知PeerA。
RTCP报文协议链接:https://tools.ietf.org/html/rfc3611
在webrtc里面函数实现如下:
cricket::BaseChannel::ProcessPacket
cricket::WebRtcVoiceMediaChannel::OnRtcpReceived
webrtc::internal::Call::DeliverPacket
webrtc::internal::Call::DeliverRtcp
webrtc::internal::AudioReceiveStream::DeliverRtcp
webrtc::voe::ChannelProxy::ReceivedRTCPPacket
webrtc::voe::Channel::ReceivedRTCPPacket
webrtc::ModuleRtpRtcpImpl::IncomingRtcpPacket
webrtc::RTCPReceiver::IncomingPacket
webrtc::RTCPReceiver::ParseCompoundPacket
webrtc::RTCPReceiver::HandleReceiverReport
webrtc::rtcp::ReceiverReport::Parse
webrtc::rtcp::ReportBlock::Parse
二、环路延时计算原理
PeerA到PeerB的环路延时,可以理解为T2-T1的时间。
但是一般PeerB收到报文后,系统处理延时问题,不会立即发送pong响应,在计算环路延时的时候,需要把PeerB处理的系统延时响应减去。
在webrtc里面函数实现如下:
cricket::BaseChannel::ProcessPacket
cricket::WebRtcVideoChannel::OnRtcpReceived
webrtc::internal::Call::DeliverPacket
webrtc::internal::Call::DeliverRtcp
webrtc::internal::VideoSendStream::DeliverRtcp
webrtc::internal::VideoSendStreamImpl::DeliverRtcp
webrtc::ModuleRtpRtcpImpl::IncomingRtcpPacket
webrtc::RTCPReceiver::IncomingPacket
webrtc::RTCPReceiver::ParseCompoundPacket
webrtc::RTCPReceiver::HandleReceiverReport
webrtc::RTCPReceiver::HandleReportBlock
三、丢包率和环路延时传递编码器流程
在webrtc里面函数实现如下:
VideoStreamEncoder::EncodeVideoFrame
VideoSender::AddVideoFrame------------在这个函数中读取全局变量encoder_params_,判断是否需要调整视频参数。
VideoSender::SetEncoderParameters
VCMGenericEncoder::SetEncoderParameters
H264EncoderImpl::SetChannelParameters---传递丢包率和环路延时参数。
不过webrtc检测出来的丢包和环路延时,在算法模块,没有做任何动作。主要是在REMB、NACK等模块进行调整。