以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
备注
这里仅是RTCP报文的环路延时和丢包率的计算。实际的QOS用的不是这个机制。