nginx-rtmp内网回源架构
一 需求问题
外网服务器接受客户端的hls回放请求,希望能通过外网服务器回源内网的录制机上的录像文件。
二 问题点
(1)内网录制机如何主动连接外网服务器
(2)外网服务器如何标识和内网录制机的连接
(3)连接断开后,如何找回
三 实现方案
Hls回放请求响应流程
(1) 内网录制机和CMS建立常连接
(2) 外网CMS服务器接受客户端的hls回放请求
(3) CMS服务器返回302指向到外网服务器,并在url中带上会话id信息
例如:http://easycms/record/a_record.m3u8
302->http://service/sessionid/record/a_record.m3u8
(4) CMS通知内网nvr向外网服务发起连接,并发送会话id信息
(5) 外网服务器收到nvr的请求,解析出会话id和客户端请求匹配
(6) 内网nvr和本机建立http常连接
(7) 外网服务器将客户端的回放请求转发给内网的nvr录制机
(8) Nvr录制机将回放请求发给本机http服务
(9) http服务响应请求,原路返回hls数据流
整体流程图如下:
五 系统缺陷
无支持多个客户端连接对应一个nvr录制机到外网服务器的连接,因为是通过唯一的会话id匹配的,后期采用连接池方案,解决这个问题。