WebRTC流媒体服务器常用架构

webrtc虽然是一项主要使用p2p的实时通讯技术,本应该是无中心化节点的,但是在一些大型多人通讯场景,如果都使用端对端直连,端上会遇到很带宽和性能的问题,所以就有了下图的三种架构。
在这里插入图片描述

一、Mesh架构

即:每个端都与其它端互连。以上图最左侧为例,5个浏览器,二二建立p2p连接,每个浏览器与其它4个建立连接,总共需要10个连接。如果每条连接占用1m带宽,则每个端上行需要4m,下行带宽也要4m,总共带宽消耗20m。而且除了带宽问题,每个浏览器上还要有音视频“编码/解码”,cpu使用率也是问题,一般这种架构只能支持4-6人左右,不过优点也很明显,没有中心节点,实现很简单。

二、MCU (MultiPoint Control Unit)

这是一种传统的中心化架构(上图中间部分),每个浏览器仅与中心的MCU服务器连接,MCU服务器负责所有的视频编码、转码、解码、混合等复杂逻辑,每个浏览器只要1个连接,整个应用仅消耗5个连接,带宽占用(包括上行、下行)共10m,浏览器端的压力要小很多,可以支持更多的人同时音视频通讯,比较适合多人视频会议。但是MCU服务器的压力较大,需要较高的配置。

三、SFU(Selective Forwarding Unit)

上图右侧部分,咋一看,跟MCU好象没什么区别,但是思路不同,仍然有中心节点服务器,但是中心节点只负责转发,不做太重的处理,所以服务器的压力会低很多,配置也不象MUC要求那么高。但是每个端需要建立一个连接用于上传自己的视频,同时还要有N-1个连接用于下载其它参与方的视频信息。所以总连接数为5*5,消耗的带宽也是最大的,如果每个连接1M带宽,总共需要25M带宽,它的典型场景是1对N的视频互动。

目前,随着5G技术的推广,可以预见带宽越来越不是问题,所以SFU在未来,可能会更有优势。

建议:如果规模不大(5人以下) Mesh框架就够用了,毕竟实现简单;如果50人以下,且带宽有限,选择MCU比较适合;如果规模更大,且带宽良好,SFU相对更适合。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
百万级高并发WebRTC流媒体服务器设计与开发是一门涉及到视频通信、网络协议和Web开发的高级课程。该课程的目标是培养学生对大规模高并发视频流媒体服务器的设计和开发能力。 在这门课程中,学生将学习如何设计和构建一个支持数百万并发连接的流媒体服务器。课程将涵盖以下内容: 1. WebRTC基础知识:学生将学习WebRTC协议的基本原理和工作方式,了解传输控制协议(TCP)与用户数据报协议(UDP)之间的差异,以及实时通信协议(RTC)。 2. 服务器架构设计:学生将学习如何设计一种高可扩展性的架构,以处理大量并发连接和视频流的传输。他们将学习使用分布式系统和负载均衡来优化服务器的性能和可用性。 3. 流媒体编解码技术:学生将学习不同的视频编解码算法,并了解实时流媒体传输的特点和挑战。他们将学习如何处理音频和视频数据的编码和解码,并了解相关的压缩和解压缩技术。 4. 网络安全和数据隐私:学生将研究网络安全和数据隐私方面的问题,并学习如何在流媒体服务器中实施安全措施,保护用户的数据和隐私。 5. 实际项目开发:学生将参与实际的项目开发,设计并实现一个具有百万级高并发连接的WebRTC流媒体服务器。他们将学习如何在服务器上进行性能优化,并解决实时视频传输中遇到的各种问题。 这门课程将提供相关的教材、参考书籍和在线资源。学生将通过实际编程练习和团队项目来提高他们的实践能力,并通过课堂讨论和评估来加深对课程内容的理解。 以上是对百万级高并发WebRTC流媒体服务器设计与开发课程资源的简要回答,该课程将为学生提供深入了解WebRTC流媒体服务器的机会,并为他们在相关领域的职业发展打下坚实的基础。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值