EasyDarwin最主要的模块便是转发模块,转发模块完成从端口接收RTP数据并根据播放需求发送到播放端。
最典型的模式便是通过ffmpeg推流到EasyDarwin端口,然后vlc客户端请求播放,EasyDarwin将收到的RTP数据再发送给vlc。
本次博文主要便是分析转发流ReflectorStream及相关类
主要涉及的相关类如下
- ReflectorSession
- ReflectorStream
- ReflectorSender
- ReflectorSocketPool
- ReflectorSocket
- ReflectorPacket
首先一个转发会话(ReflectorSession)可以有多股转发流(ReflectorStream),在ReflectorSession中维持了一个ReflectorStream的数组。
一股转发流(ReflectorStream)有两个转发送器(ReflectorSender),一个用于发送RTP数据,一个用于发送RTCP数据。
一个发送器(ReflectorSender)对应一股转发流(ReflectorStream)。
一股转发流(ReflectorStream)包含一对UDPSocket(UDPSocketPair)。
在转发流中具体新建的是ReflectorSocket。
为何可以使用ReflectorSocket来构建UDPSocketPair而本该使用UDPSocket来构建,因为ReflectorSocket继承自UDPSocket。
一对ReflectorSocket其中一个用于RTP数据的接收,另一个用于RTCP数据的接收,并且都绑定到服务器IP和Port。
通过父类UDPSocket的RecvFrom函数一直从绑定端口接收推流端发送过来的数据。
ReflectorSocket接收到数据后就会对数据进行处理,处理的数据就是ReflectorPacket。
至此ReflectorStream及相关类分析完成,最后贴一个关系解析图。