live555是一个高效简单且优秀的流媒体开源项目,我们可以轻松的基于他开发rtspclient或rtspserver,分别实现rtsp播放器或rtsp点播服务器,但是如果想基于他开发rtsp 代理服务器就没有那么简单了,接下来,我会分享一系列的文章来介绍如何实现,欢迎感兴趣的同学关注!
好了,关子卖完了,讲一下实现的方法。其实live555项目默认自带了一个rtsp代理服务器:live555ProxyServer.cpp,打开这个文件看一下,或者调试一下,在启动参数里面设置需要代理的前向rtsp url,然后给指定一个后向stramId;启动进程后,会打印代理流的信息,前向代理流url,后向streamId等,一一对应。因为这个太简单了,我就不贴图了。
到此,本文结束。^v^,是不是很简单呢?
如果你的需求仅如此,那就是这么简单。如果你还有更复杂的需求,例如:
1、需要动态的指定或异步查询前向代理的rtsp url;(live555是单线程的,异步查询并不容易)
2、期待实现live555多线程的流媒体代理;(live555并不支持多线程,官方答复比较敷衍:推荐多进程,原则上实现多线程也很简单。实际并不简单,后续文章我会讲解)
3、期待live555支持更多媒体并发代理;(live555使用select进行事件循环调度,如果是rtp over udp,代理一次媒体流,可能就需要前向1 rtsp fd,1 audio rtp fd,1 video rtp fd,1 audio rtcp fd,1 video rtcp fd共5fd,后向同样5fd,共10个fd资源,select在Linux下最多1024个fd,这样最大的并发量也就100路流而已,否则 select的 FD_SET溢出了;所以这样就要支持epoll了,后续我会分享epoll实现和完整的替换代码)
算了,就列这么多了,其他的暂时也想不起来。后续我先讲一下,怎么解决上述三个问题,再有时间的话,遇到了就补上吧!