Mediasoup源码分析(1)——架构分析
1. 设计架构图
-
Worker 一个Worker代表着一个运行在单核CPU上并处理Router实例的mediasoup C++子进程; Transport Transport将终端与MediaSoup Router连接起来,并通过在其上创建的Producer和Consumer实例实现双向媒体传输,实现了下面3种Transport: WebRtcTransport 一个WebRtcTransport代表着一个WebRTC终端和MediaSoup通过ICE和DTLS过程协商的网络路径。WebRtcTransport可用于接收媒体、发送媒体或同时接收和发送媒体。MediaSoup没有限制。但是,由于其设计,mediasoup-client和libmediasoupclient要求区分用于发送和接收的WebRtcTransport。 PlainRtpTransport 一个PlainRtpTransport代表着一个通过它传输纯RTP和RTCP的网络路径。 PipeTransport 一个PipeTransport代表着一个通过它传输纯RTP和RTCP的网络路径。PipeTransport旨在实现在同一主机或不同主机上两个匹配的Router实例间的互相通信; Producer 一个Producer代表着一个被注入到MediaSoup Router的音频或视频源。它是在定义媒体数据包传送方式的Transport之上创建的。
每个Transport 最多 有2个Producer(Video、Audio)和2个Consumer(Video、Audio)
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/