文档章节

Kurento 之 WebRTC 统计

chapin
 chapin
发布于 2017/02/17 11:48
字数 1027
阅读 123
收藏 1
点赞 0
评论 0

介绍

WebRTC流(音频,视频或数据)可能丢失,并且经历不同数量的网络延迟。 为了评估WebRTC应用程序的性能,可能需要能够监视底层网络和媒体管道的WebRTC功能。

为此,Kurento为服务器端(Kurento Media Server,KMS)提供了WebRTC统计数据收集。 此功能的实现遵循W3C WebRTC的统计API中提供的指南。 因此,KMS中收集的统计数据可以分为两组:

  • inboundrtp:KMS接收流的统计信息。
  • outboundrtp:KMS发送流的统计信息。

API 描述

通常,WebRTC统计信息收集功能由KMS提供,并通过不同的Kurento客户端实现(Java,JavaScript客户端提供开箱即用)来使用。 要读取这些统计信息,首先应该使用Media Pipeline对象的setLatencyStats方法启用它们。 使用Kurento Java客户端,操作如下:

String kmsWsUri = "ws://localhost:8888/kurento";
KurentoClient kurentoClient = KurentoClient.create(kmsWsUri);
MediaPipeline mediaPipeline = kurentoClient.createMediaPipeline();
mediaPipeline.setLatencyStats(true);

// ...

使用 JavaScript 客户端:

var kmsWsUri = "ws://localhost:8888/kurento";
kurentoClient(kmsWsUri, function(error, kurentoClient) {
   kurentoClient.create("MediaPipeline", function(error, mediaPipeline) {
      mediaPipeline.setLatencyStats(true, function(error){

         // ...

      });
   });
});

一旦启用WebRTC统计,第二步是使用媒体元素的getStats方法读取统计值,例如,读取Java中的WebRtcEndpoint对象的统计信息:

WebRtcEndpoint webRtcEndpoint = new WebRtcEndpoint.Builder(mediaPipeline).build();
MediaType mediaType = ... // it can be MediaType.VIDEO, MediaType.AUDIO, or MediaType.DATA
Map<String, Stats> statsMap = webRtcEndpoint.getStats(mediaType);

// ...

JavaScript操作:

mediaPipeline.create("WebRtcEndpoint", function(error, webRtcEndpoint) {
   var mediaType = ... // it can be 'VIDEO', 'AUDIO', or 'DATA'
   webRtcEndpoint.getStats(mediaType, function(error, statsMap) {

      // ...

   });
});

请注意,WebRTC统计信息将作为map读取。 因此,此集合的每个条目都有一个键和一个值,其中键是特定统计量,在读取时具有给定值。 考虑到这些值参考实时属性,因此这些值随时间变化,这取决于多个因素(例如网络性能,KMS负载等)。 统计的完整描述在KMD接口描述中定义。 最相关的统计数据如下:

  • ssrc: 同步源(SSRC)。
  • firCount: 统计发送方接收的完整内部请求(FIR)数据包的总数。 此指标仅对视频有效,并由接收方发送。
  • pliCount: 统计由发送方接收并由接收方发送的包丢失指示(PLI)包的总数。
  • nackCount: 统计由发送方接收并由接收方发送的否定确认(NACK)分组的总数。
  • sliCount: 统计发送方接收的分片丢失指示(SLI)分组的总数。 此指标仅对视频有效,并由接收方发送。
  • remb: 接收器估计最大比特率(REMB)。 此指标仅适用于视频。
  • packetsLost: 统计SSRC丢失的RTP数据包总数。
  • packetsReceived: 统计SSRC接收的RTP数据包总数。
  • bytesReceived: 统计SSRC接收的字节总数。
  • jitter: SSRC的以秒为单位的包抖动。
  • packetsSent: 统计SSRC发送的RTP数据包总数。
  • bytesSent: 统计SSRC发送的字节总数。
  • targetBitrate: 当前配置SSRC的比特率目标,以比特每秒为单位。
  • roundTripTime: 基于RTCP时间戳的SSRC估计往返时间(秒)。
  • audioE2ELatency: 以纳秒为单位测量的端到端音频延迟。
  • videoE2ELatency: 以纳秒为单位测量的端到端视频延迟。

总而言之,在KMS中收集WebRTC统计的过程可以总结为两个步骤:1)启用WebRTC统计; 2)读取WebRTC。 此过程如下图所示。 此图还描述了Kurento客户端和KMS之间根据Kurento协议交换的JSON-RPC消息:

Sequence diagram for gathering WebRTC statistics in KMS

Example

有一个正在运行的教程,使用WebRTC收集如前所述信息。 这个演示已经使用JavaScript客户端实现,它可以在GitHub上获得:kurento-loopback-stats

从媒体管道的角度来看,这个演示应用程序包含一个WebRtcEndpoint在环回。 一旦演示启动并运行,WebRTC启用并按1秒钟的速率收集。

除了KMS WebRTC统计,客户端(即浏览器WebRtc对等)也由应用程序收集。 这是使用由peerConnection对象提供的标准方法完成的,即使用其方法getStats。 请查阅位于index.js文件中的JavaScript逻辑以了解实现细节。

两种WebRTC统计值(即浏览器和KMS端)在应用程序GUI中每秒更新和显示,如下所示:

tatistics results in the kurento-loopback-stats demo GUI

© 著作权归作者所有

共有 人打赏支持
chapin
粉丝 18
博文 83
码字总数 102961
作品 0
成都
程序员
WebRTC的拥塞控制和带宽策略

网络的波动带来的卡顿直接影响着用户的体验,在WebRTC中设计了一套基于延迟和丢包反馈的拥塞机制(GCC)和带宽调节策略来保证延迟、质量和网路速度之间平衡,本文中重点是介绍基于trendline...

caoshangpa ⋅ 05/29 ⋅ 0

了不起的WebRTC:生态日趋完善,或将实时音视频技术白菜化

本文原文由声网WebRTC技术专家毛玉杰分享。 1、前言 有人说 2017 年是 WebRTC 的转折之年,2018 年将是 WebRTC 的爆发之年,这并非没有根据。就在去年(2017年),WebRTC 1.0 标准草案出炉(...

JackJiang2011 ⋅ 06/04 ⋅ 0

WebRTC技术大会将于5月19日在上海举行

一场WebRTC技术大会即将在上海上演,这是一次面向全球的WebRTC技术的技术实践和应用案例的梳理与展示,预计将有超过250名的多媒体开发工程师、技术负责人、产品负责人及高端行业用户出席本次...

LiveVideoStack ⋅ 05/02 ⋅ 0

5月19-20日WebRTCon 2018 梳理全球WebRTC技术实践与案例

4月17日,距离WebRTCon 2018举行还有一个多月的时间,这是由音视频技术社区LiveVideoStack发起的WebRTC生态大会。大会将聚焦WebRTC技术实践与应用案例两大主线,旨在为WebRTC的7年长跑做一次...

vn9plgzvnps1522s82g ⋅ 04/17 ⋅ 0

kurento学习进阶一(源码库依赖关系)

Developer Guide¶ This section is a comprehensive guide for development of Kurento itself. The intended reader of this text is any person who wants to get involved in writing c......

liuweihui521 ⋅ 04/13 ⋅ 0

鹅厂优文|打通小程序音视频和webRTC

欢迎大家前往腾讯云+社区,获取更多腾讯海量技术实践干货哦~ 作者:腾讯视频云终端技术总监常青, 2008 年毕业加入腾讯,一直从事客户端研发相关工作,先后参与过 PC QQ、手机QQ、QQ物联 等产...

腾讯云加社区 ⋅ 05/04 ⋅ 0

学习多媒体开发的正确姿势?陈功:看书 啃代码 搞插件

陈功说,要想学好多媒体开发,首先需要兴趣,接下来还需要好的方法。LiveVideoStack邮件采访了声网Agora首席WebRTC架构师,畅聊了自己的成长经历,WebRTC的演进趋势等。陈功表示,WebRTC的未...

vn9plgzvnps1522s82g ⋅ 04/13 ⋅ 0

【Win7 x64 + VS2010 SP1成功编译WebRTC】

bill愚钝,几经折腾才编译成功,故写下博文记之,以节约后来者的时间。 其实整个过程按照GOOGLE WEBRTC官网的步骤一步一步无遗漏地做便可。只是最后可能遇到一些编译时错误以及VS2010上的配置...

技术小胖子 ⋅ 2017/11/16 ⋅ 0

Facebook视频支持AV1

Facebook尝试在自己的视频服务中使用AV1编码,并通过“切片+分布式”的方式解决AV1编码延迟的问题。LiveVideoStack对文章进行了翻译。 文 / Daniel Baulig,Yu Liu 译 / 蒋默邱泽 审校 / 包研...

LiveVideoStack ⋅ 04/29 ⋅ 0

取代 FlashP2P,H5P2P 将成为 WebP2P 主流

5 月 19、20 日,行业精英齐聚的 WebRTCon 2018 在上海举办。又拍云 PrismCDN 项目负责人凌建发在大会做了《又拍云低延时的 WebP2P 直播实践》的精彩分享。 分享介绍了 WebP2P 行业将从 Flas...

又拍云 ⋅ 06/05 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

IDEA PermGen space内存溢出

解决方案: File -> Settings -> Build, Execution, Deployment / Build Tools / Maven / Runner下,找到VM Options选项,默认是空的,改为如下内容(或更大值)...

快乐的小火柴 ⋅ 16分钟前 ⋅ 0

前端常见跨域解决方案

什么是跨域? 跨域是指一个域下的文档或脚本试图去请求另一个域下的资源,这里跨域是广义的。 广义的跨域: 1.) 资源跳转: A链接、重定向、表单提交2.) 资源嵌入: <link>、<script>、<im...

临江仙卜算子 ⋅ 17分钟前 ⋅ 0

系统管理命令service

service命令用来控制系统服务的实用工具,例如启动、停止、重启和关闭系统服务,以及当前状态。当然也可以直接操作,例如/etc/init.d/mysqld restart等。 语法 service (选项)(参数) 选项...

Jpchina ⋅ 22分钟前 ⋅ 0

MySQL 联合索引的命中规则

为什么要用联合索引? 对于查询语句“SELECT T.* FROM T WHERE T.c1=1 AND T.c3=2”涉及到两列,这个时候我们一般采用一个联合索引(c1, c3);而不用两个单列索引,这是因为一条查询语句往往应...

hensemlee ⋅ 29分钟前 ⋅ 0

Spring 自动组件扫描

通常情况下都是在XML配置文件中手动声明Bean和组件的。不过Spring也可以自动扫描组件实例化Bean,这样就可以避免在XML文件中繁琐的Bean声明。 手动声明Bean: 这里不再啰嗦,就是简单地在XML...

霍淇滨 ⋅ 34分钟前 ⋅ 0

MapReduce简单需求分析-共同好友及查找互粉的情况

MapReduce的设计,最重要的是要找准key,然后制定一系列的数据处理流程。MapReduce的Map中,会把key相同的分配到同一个reduce中,对于key的选择,可以找到某个相同的因素。以下面的几个例子说...

Jason_typ ⋅ 36分钟前 ⋅ 0

springboot多数据源自动切换

SpringBoot多数据源切换,先上配置文件: 1.pom: <?xml version="1.0" encoding="UTF-8"?><project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/20......

JackyRiver ⋅ 38分钟前 ⋅ 0

Boost库编译应用

版本:Boost 1.66.0 Windows库编译 官网指南:直接执行bootstrap.bat处理文件即可,可以我却遇到一堆的问题。 环境:Windows 10 + Visual Studio 2017 Boost编译出来库命名 boost库生成文件命...

水海云 ⋅ 42分钟前 ⋅ 0

解决Eclipse发布到Tomcat丢失依赖jar包的问题

如果jar文件是以外部依赖的形式导入的。Eclipse将web项目发布到Tomcat时,是不会自动发布这些依赖的。 可以通过Eclipse在项目上右击 - Propertics - Deployment Assembly,添加“Java Build ...

ArlenXu ⋅ 42分钟前 ⋅ 0

iview tree组件层级过多时可左右滚动

使用vue+iview的tree组件,iview官网iview的tree树形控件 问题描述:tree层级过多时左右不可滚动 问题解决:修改overflow属性值 .el-tree-node>.el-tree-node_children { overflow: vi...

YXMBetter ⋅ 44分钟前 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部