Mediasoup源码分析(1)——架构分析

1. 设计架构图

Mediasoup源码分析(1)——架构分析_第1张图片

  • Worker
    一个Worker代表着一个运行在单核CPU上并处理Router实例的mediasoup C++子进程;

  • Router
    Router用于注入、选择和转发通过Transport实例创建的媒体流;

  • Transport
    Transport将终端与MediaSoup Router连接起来,并通过在其上创建的ProducerConsumer实例实现双向媒体传输,实现了下面3种Transport

    • WebRtcTransport
      一个WebRtcTransport代表着一个WebRTC终端和MediaSoup通过ICE和DTLS过程协商的网络路径。WebRtcTransport可用于接收媒体、发送媒体或同时接收和发送媒体。MediaSoup没有限制。但是,由于其设计,mediasoup-clientlibmediasoupclient要求区分用于发送和接收的WebRtcTransport

    • PlainRtpTransport
      一个PlainRtpTransport代表着一个通过它传输纯RTP和RTCP的网络路径。

    • PipeTransport
      一个PipeTransport代表着一个通过它传输纯RTP和RTCP的网络路径。PipeTransport旨在实现在同一主机或不同主机上两个匹配的Router实例间的互相通信;

  • Producer
    一个Producer代表着一个被注入到MediaSoup Router的音频或视频源。它是在定义媒体数据包传送方式的Transport之上创建的。

  • Consumer
    一个Consumer代表着一个被MediaSoup Router转发到终端的音频或视频源。它是在定义媒体数据包传送方式的Transport之上创建的。

每个Transport 最多 有2个Producer(Video、Audio)和2个Consumer(Video、Audio)

2. 核心类图

Mediasoup源码分析(1)——架构分析_第2张图片

业务实现需考虑增加以下类:

  • Host
    主机或服务器,一个N核CPU的Host有N个Worker

  • Room
    会议,一个Room有1到多个Router,有0到多个Participant

  • Participant
    参会人或观看方,每个Participant 有0到多个Transport(主流和辅流)

3. 参考资料

  • 官网V3设计文档
    https://mediasoup.org/documentation/v3/mediasoup/design/

  • 官网V3 API文档
    https://mediasoup.org/documentation/v3/mediasoup/api/

你可能感兴趣的:(WebRTC)