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数据流

整体流程图如下:

nginx-rtmp内网回源架构

系统缺陷

无支持多个客户端连接对应一个nvr录制机到外网服务器的连接,因为是通过唯一的会话id匹配的,后期采用连接池方案,解决这个问题。