• EasyDarwin开源流媒体服务器进行RTSP转发过程中将sdp由文件存储改成内存索引


    —本篇由团队成员Fantasy供稿!

    原始版本

    在Darwin Streaming Server版本中,推送端DoAnnounce的时候后服务器会根据easydarwin.xml中配置的movies_folder目录生成一个sdp文件,存放推送流的sdp文件信息,在拉取客户端,Darwin Streaming Server接收到DESCRIBE请求,检查服务器movies_folder目录下是否有对应请求路径的sdp文件,如果有则返回对应的sdp文件;

    原始版本问题

    很多时候,Darwin Streaming Server会由于权限问题无法创建movies_folder目录,或者无法在movies_folder目录下创建对应的sdp文件,并将sdp信息存进去,这样一来,就会造成推流或者拉流失败。

    EasyDarwin解决办法

    不再将sdp信息存放到movies_folder目录下的文件中,通过一个全局的map存储,建立StreamName到sdp信息context的索引。通过类CSdpCache管理,详见EasyDarwin文件sdpCache.h和sdpCache.cpp文件。实现比较简单,就不做详细介绍了。使用的单例模式,确保唯一性。

    1. 在推送DoAnnounce的时候生成sdp索引,
    2. 拉流的时候不再是遍历movies_folder目录,直接从sdpCache中查询(仅限于QTSSReflectorModule,FileModule仍然是读文件,因为访问的就是文件)
    3. ReflectorSession析构的时候,删除sdpCache中对应的map项。
    4. 更多信息参看EasyDarwin流媒体服务器Github:https://github.com/EasyDarwin/EasyDarwin

    获取更多信息

    邮件:support@easydarwin.org

    WEB:www.EasyDarwin.org

    Copyright © EasyDarwin.org 2012-2016

    EasyDarwin

  • 相关阅读:
    Threaten Model
    什么是虚拟主机
    http代理服务器
    什么是https
    缓存的实现原理
    Cookie和Session
    HTTP协议详解
    心路历程——毕设程序mr跑不通的问题
    bash: hadoop:command not found
    Mapreduce 测试自带实例 wordcount
  • 原文地址:https://www.cnblogs.com/babosa/p/5904654.html
Copyright © 2020-2023  润新知