机器性能对 webrtc 点对点通信延迟的影响分析

1.背景介绍

在 chromium 浏览器中使用 webrtc 实现点对点通信时,由于刚开始发送端虚拟机只分配了一个处理器核,接收端处理器性能足够,导致通过 webrtc 共享桌面的视频播放延时达到 4~6 秒,所以想试验一下,随着发送端处理器核数增加,webrtc 的延时有什么样的变化规律。
机器配置说明:

p2p内核数内存大小(G)
接收端4核8线程16
发送端1——2——42——4——8

本文只对发送端的性能做测试,取的变量:
(1)当发送端虚拟机内存大小固定为 8G 时,内核数从 1 到 4 变化;
(2)当发送端虚拟机内核数固定为4时,发送端内存大小从 2G 到 8G 变化时。

备注:本文的统计数据取自接收端 webrtc 日志文件。

webrtc 日志文件记录的统计信息如下图:
这里写图片描述

2. 处理器内核

发送端虚拟机内存保持 8G 不变,改变处理器的核数,发送端播放在线视频,观察接收端延时情况。

2.1 共享音频

处理器核数共享屏幕总时长(s)音视频同步延时(ms)解码时间(ms)抖动缓冲区延时(ms)当前延时(ms)平均帧间延时(ms)最大帧间延时(ms)
1266203429667741399920
217082852190203355017
4210899629711235415

2.2 不共享音频

处理器核数共享屏幕总时长(s)解码时间(ms)抖动缓冲区延时(ms)当前延时(ms)平均帧间延时(ms)最大帧间延时(ms)
1235254516824310537
216602113126355010
418533698336388

2.3 小结

(1)数据分析

  • 在单核的情况下,接收端视频无法观看,延时卡顿严重,播放一段时间就会卡死。
  • 在双核的情况下,接收端视频比较流畅,延时在 1 秒以内,两端基本同步,可以正常观看,并且不会感到明显的延时。
  • 在四核的情况下,接收端视频比较流畅,延时在 1 秒以内,两端基本同步,可以正常观看,并且不会感到明显的延时。

(2)小结
在使用 webrtc 进行屏幕共享时,发送端的处理器的核数最小为 2 ,这样共享屏幕才能基本可用。

3. 内存变化

发送端虚拟机处理器内核保持 4 核不变,内存大小取 2G, 4G, 8G,观察共享在线视屏时的接收端延时情况。

3.1 共享音频

内存大小(G)共享屏幕总时长(s)音视频同步延时(ms)解码时间(ms)抖动缓冲区延时(ms)当前延时(ms)平均帧间延时(ms)最大帧间延时(ms)
2164945043165180391080
41740584311312735980
8210899629711235415

3.2 不共享音频

内存大小(G)共享屏幕总时长(s)解码时间(ms)抖动缓冲区延时(ms)当前延时(ms)平均帧间延时(ms)最大帧间延时(ms)
216973148163371360
4892314415835494
818533698336388

3.3 小结

(1)数据分析
在发送端虚拟机内存大小为 2G 、4G 、8G ,接收端都可以正常的播放视频,感觉不到明显的卡顿或延时。
(2)小结
在使用 webrtc 点对点通信功能进行共享桌面时,通信延时对内存的变化不是很敏感。当然,内存越大效果越好,但是这种变化不像处理器那样明显。

4.结论

以上分析过程中并没有严格的控制变量,接收端主机处于正常工作状态,打开了较多的应用,一边通过虚拟机向主机共享屏幕,一边在主机上正常做开发的工作,并且长时间没有重启机器,可能导致负载处于波动状态,如果能够保证每一次测试之前的两端环境都是重置过的,实验数据会更有说服力,但是这样操作过于麻烦。
但是根据上面的数据还是可以得出一些简单的结论:
(1)在使用 webrtc 的点对点通信功能进行屏幕共享时,有基本的机器性能要求;
(2)发送端为虚拟机的情况下,处理器要双核及以上配置,内存 2G 以上(没有测 1G 的情况,因为 1G 内存已经很少见);
(3)选用性能更好的 CPU,可以缩短延时,不过需要考虑成本问题。

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值