SRS总结(4)

发布时间 2023-09-20 15:47:10作者: 泽良_小涛

10.国产开源流媒体SRS4.0对视频监控GB28181的支持

参考:https://mp.weixin.qq.com/s/VIPSPaBB5suUk7_I2oOkMw

https://github.com/xialixin/srs_code_note/blob/master/doc/srs_gb28181.md

https://www.cnblogs.com/hahaha111122222/p/16725612.html

https://blog.csdn.net/Alan_ran/article/details/126739871

https://blog.csdn.net/adkada1/article/details/121121901

10.1前言

本篇文章主要是介绍下国产开源流媒体SRS涉及的入门资料,SRS前期对标的nginx-rtmp-module,是国内第一款真正开源的流媒体服务,应用在直播和RTC领域。但是成立同学志存高远,不仅仅局限于某一个行业,近期WebRTC、SRT、GB28181支持的都很快,希望大家都能参与进来,支持国产开源流媒体发展壮大。

在我看来,推荐SRS作为流媒体人学习和使用的N个理由:

1. SRS最大的特点就是简单,表现在代码架构简单,实现简单,部署简单,运维简单;

2. 源代码彻底开源,采用了IMT非常宽松的开源协议,同时Git上有非常丰富的Wiki文档资料和提交了大量Issuse,非常适合学习和商用;

3. SRS有丰富的周边开发工具,有自研播放器和性能压测工具,分分钟搭建一套直播系统,直接可以上手相应环境验证功能和代码调试;

4. SRS已经迭代到4.0版本,功能很丰富,支持多源输入也支持多协议分发,你能看到的RTMP、HLS、DASH、RTSP、GB28181、WebRTC、SRT、HTTP-FLV都支持接入和分发;

5. SRS即支持小规模集群也支持大规模集群,特别是对CDN业务的关键特性的支持,性能稳定性都线上跑过和压测过,质量有一定的保障,定位成运营级的互联网直播服务器此言非虚;

10.2SRS官网介绍:

SRS定位是运营级的互联网直播服务器集群,追求更好的概念完整性和最简单实现的代码。SRS提供了丰富的接入方案将RTMP流接入SRS, 包括推送RTMP到SRS、推送RTSP/UDP/FLV到SRS、拉取流到SRS。 SRS还支持将接入的RTMP流进行各种变换,譬如将RTMP流转码、流截图、 转发给其他服务器、转封装成HTTP-FLV流、转封装成HLS、 转封装成HDS、支持SRT流、录制成FLV/MP4。SRS包含支持大规模集群如CDN业务的关键特性, 譬如RTMP多级集群、源站集群、VHOST虚拟服务器、无中断服务Reload、HTTP-FLV集群。此外,SRS还提供丰富的应用接口, 包括HTTP回调、安全策略Security、HTTP API接口、RTMP测速。SRS在源站和CDN集群中都得到了广泛的应用Applications。

10.3SRS基本资料:

Wiki地址,里面有上百篇详细文档,第一入手资料:

https://github.com/ossrs/srs/wiki

Git分支,可以看源码:

https://github.com/winlinvip/srs

官网,有安装包,客户端供大家测试体验:

http://www.ossrs.net/srs.release/releases/

10.4流媒体参考资料:

1.参考资料1,包含了SRS3.0源码阅读笔记,也是SRS支持国标的开发者。同时分支不局限SRS学习,还有大量RTC领域的资料,还包括cdn原理实现,连麦,会议直播,微信小程序会议接入,sip客户端会议接入等方案文档,物联网调查报告等:

https://github.com/xialixin/srs_code_note

2.参考资料2, 潇湘落木的git项目,主要包含各种流媒体涉及的编码、封装、传输协议等文档的资料整理,以及一些测试素材和测试工具:

https://github.com/ty6815/AvStackDocs

10.5支持监控GB28181背景和定位:

SRS是一款开源流媒体,适合直播以及低延时流媒体领域,但是从来不设限,可以应用在直播、视频会议、在线教育等场景。同时视频领域还有两大块:广电和视频监控,随着互联网的迅速发展,视频监控设备上云的需求越来越多,以前还可以私有化局域网里面搞一搞,但是随着移动互联网的发展,视频监控有大量的移动端直播需求,让人随时随地能看处理监控报警事件、查看回放视频是刚需。同时这几年红黄蓝幼儿园事件、不良商家黑暗料理问题层出不穷,所以视频监控从行业逐渐走向民用,平安校园、明厨亮灶、智慧社区、智能家居等场景的落地,更是加快了视频监控上云的趋势。

 SRS我看Issue大概是19年有人提问,然后19年后半年成立这边应该做过一些调研,SRS也跟进了下,但是跟进方向不对,年末跟成立聊过这个问题,才最终确定SRS开始支持这块。

关于视频监控上云前面写过文章,分析过《视频监控摄像头的互联网化实践思路》,简单来说:

1. SRS如果支持RTSP拉流,由于摄像头一般都在局域网,没有外网访问途径,如果要把SRS作为代理服务部署在用户侧,这用起来不靠谱也不符合SRS的定位,pass掉了,也意味着ONVIF协议集成到SRS里面没有多大意义;

2. 既然主动拉流不靠谱,那就支持摄像头推流,SRS目前支持RTSP推流,但是摄像头目前支持该种方法的很少,一般都是在局域网拉流,所以SRS支持了没用,设备端不支持;

3. 其次部分设备端支持RTMP推流,那么这点作为SRS基本功能肯定是支持的,但是并不是所有设备端都支持RTMP推流,设备也不仅仅包含摄像头,还包括NVR,边缘服务器等;

4. 推流既然是方向,还有没有其它形式支持设备端推流?有的,国内设备端用的国家标准GB28181协议,除了消费类家庭摄像头,基本大部分摄像头都支持该协议,便宜的二三百,贵点的两三千设备,都是支持这个协议,所以SRS只有支持GB28181,就能覆盖90%以上的视频监控上云需求,其次支持摄像头、NVR、下级国标平台性软件统统上云;

所谓的国标GB28181协议大家简单理解为SIP+RTP即可,所以SRS为了支持视频监控行业设备上云,还是要支持国标GB28181协议。

 

但是支持GB28181协议,如果把信令和媒体收在SRS里面实现,违反了SRS的简单原则,其次信令这块对接起来非常麻烦,虽然是国家标准,但是各个厂家实现的不标准,有很多细小问题需要接入方来兼容,其次这块还有大量业务在里面,所以SRS不应该去完整实现GB协议信令部分,只需要实现媒体部分即可,换句话说只要能摄像头接进来,能把媒体流从RTP转分发为RTMP、HLS等即可。信令部分只需要提供基本的测试接入部分即可,目的只是为了SRS能跑起来,信令部分还是需要使用SRS的同学们自己实现,媒体部分会提供RestFul接口供信令调用。

10.6SRS国标部分编译

我们在华为云北京机房,编译SRS,将杭州摄像头本地的流推到北京机房,再通过RTMP分发回杭州客户端播放。

编译参考:

https://github.com/ossrs/srs/issues/1500

https://blog.csdn.net/wdx1632/article/details/125428929

https://blog.csdn.net/u011374856/article/details/107487363

https://github.com/ossrs/srs/issues/3176

https://blog.csdn.net/weixin_67588007/article/details/129162990

1.安装

//目前安装5.0.26版本 在git上我切换不到gb28181分支 推荐国内gitcode好用!

//下载安装

git clone https://gitcode.net/mirrors/ossrs/srs-gb28181.git

//完成后进入trunk目录

cd srs-gb28181/trunk

//配置一下

./configure --gb28181=on

//最后make

make

2.启动

./objs/srs -c ./conf/push.gb28181.conf

1.Open http://localhost:8080/ to check it(http://10.10.14.103:8080/

2. ./etc/init.d/srs status

3. ps -ef | grep srs

10.7实际测试情况

本次测试,初步验证SRS对国标支持的基本情况,主要测试了SRS能支持的设备类型和接入方式,其次测试了SRS分发RTMP流在各个播放器的播放情况和延时大致测试:

1. 基本可以支持设备直连SRS情况,大华,海康IPC直连SRS基本都已经支持起来,大华码流在解析PS流的Header可能有时存在兼容性问题,后续版本会进行处理。海康设备直连支持较好,用高低中三挡设备接入,皆可以播放。

2. 延迟情况:

IPC自带Web插件播放器(1s+) < SRSPlayer(1-2s) < 微信小程序Live_Player组件 (3-5s)< VLC(5s+) < 一般其它播放器(有累计延迟甚至达到10s+)

测试截图1:多端播放情况延时比较

https://mmbiz.qpic.cn/mmbiz_png/LMDDiaViaw3KJmWbmELwsnWeR0AOfuibk1OqhicGiaFa5BJTibtL3WlMS1yKd3qgrNrMRmbIsntqQjZsRnlicHo3lSKug/640?wx_fmt=png&wxfrom=5&wx_lazy=1&wx_co=1

测试截图2:自带播放器和微信小程序移动端播放演示比较

https://mmbiz.qpic.cn/mmbiz_png/LMDDiaViaw3KJmWbmELwsnWeR0AOfuibk1O6USThb1BVaIScWcLDuy5C5DKTqpPxuIQIKrXcKSr8ialUtQkDkYFZqg/640?wx_fmt=png&wxfrom=5&wx_lazy=1&wx_co=1

测试截图3:海康人脸机测试情况比较

https://mmbiz.qpic.cn/mmbiz_png/LMDDiaViaw3KJmWbmELwsnWeR0AOfuibk1O2SXlQy3Vz6rbvstVNF0xfwRR5YBrDLHf9kukHWib66qML8G21HvJQWA/640?wx_fmt=png&wxfrom=5&wx_lazy=1&wx_co=1

近期也有人用WebRTC进行了测试,其中WebRTC延时最低,比局域网中IPC自带的播放器延时还要低:

测试截图4:WebRTC和RTMP协议分发延时比较

https://mmbiz.qpic.cn/mmbiz_png/LMDDiaViaw3KJmWbmELwsnWeR0AOfuibk1OpyF8GbibTELhWFFksibTODQ1TmMAmErK3MQZTe1aXl8QyRZtgHiaHFpAw/640?wx_fmt=png&wxfrom=5&wx_lazy=1&wx_co=1

10.8本文总结:

这篇算是介绍SRS开源项目的第一篇文章,给了一些SRS项目的概况和资料链接。同时在本文验证了SRS4.0对监控行业GB28181协议的当前支持情况和使用方法介绍。

SRS作为直播领域国产比较有名的开源流媒体服务器,经过对nginx-rtmp-moudle的参考和学习,结合国内情况,大有超越之势。在这次疫情影响下,更多的线下场景都要搬到线上,5G的到来,视频直播和实时技术将在在线娱乐,教育、视频会议和视频监控AIOT等领域迎来新一轮的爆发。在此希望更多的人可以学习和使用SRS,无论是参与issue的讨论,还是提交一行代码抑或是对SRS功能的吐槽都算是是对开源的贡献。

11.SRS4.0 WebRTC一对一通话环境搭建与逻辑分析

参考:https://blog.csdn.net/m0_60259116/article/details/124691647

11.1环境搭建

11.1.1. 安装go语⾔环境

1.在Go语⾔官⽹找到对应的安装包(Downloads - The Go Programming Language

2.下载和解析(使用的是阿里云的Ubuntu系统):

cd /usr/local/

wget https://dl.google.com/go/go1.16.5.linux-amd64.tar.gz --no-check-certificate

tar -C /usr/local -xzf go1.16.5.linux-amd64.tar.gz

3.需要配置 GOROOT 和 PATH环境变量,在/etc/profile中配置。

vim /etc/profile

# 将环境变量添加到/etc/profile⽂件末尾。

export GOROOT=/usr/local/go

export PATH=$PATH:$GOROOT/bin:$GOBIN

4.然后使用 source /etc/profile 命令使配置文件生效,就可以在任意⽬录使用Go语言命令。

source /etc/profile

5.执行go version可以查看安装go是否成功。

11.1.2. 编译和启动srs

git clone -b v4.0.123 https://gitee.com/winlinvip/srs.oschina.git

srs.4.0.123

cd srs.4.0.123/trunk

./configure

make

./objs/srs -c conf/rtc.conf

11.1.3. 编译和启动信令服务器

1.进行srs/trunk目录下。

cd 3rdparty/signaling

make

./objs/signaling

https://img-blog.csdnimg.cn/f425a9b307da4639b69256e67d1d8389.png

11.1.4. 编译和启动web服务器

1.需要server.crt和server.key,如果没有则⽤openssl⽣成。

2.进入srs/trunk/3rdparty/httpx-static目录,执行:

# ⽣成 server.key

openssl genrsa -out server.key 2048

# ⽣成 server.crt

openssl req -new -x509 -key server.key -out server.crt -days 3650

3.编译和启动web服务器

cd 3rdparty/httpx-static

make

./objs/httpx-static -http 80 -https 443 -ssk server.key -ssc server.crt \

-proxy http://127.0.0.1:1989/sig -proxy http://127.0.0.1:1985/rtc \

-proxy http://127.0.0.1:8080/

https://img-blog.csdnimg.cn/841db787bda54b2d813044d92763d790.png

11.1.5. 进入测试页面

1.打开demo地址

https://localhost/demos/

https://192.xxx.3.6/demos/ #公网ip

https://img-blog.csdnimg.cn/3295fc84489c4e60b7bcb9fa10f98afd.png

2.输入Room和Display就可以进行1对1通话

https://img-blog.csdnimg.cn/25fcd3deb4264ef89a96d1544c9fb3eb.png

11.2. SRS4.0 WebRTC1对1通话逻辑分析

按F12打开一对一通话http页面源码,在 one2one.html?autostart=true&room=fbe219e 中可以看到,“开始通话”按钮id是btn_start,当点击按钮后,执行startDemo函数。

12.问题汇总

12.1 SRS跨域播放问题

参考:使用Linux+FFmpeg+SRS+flv.js 打造兼容性较高的直播、点播平台

12.1.1问题描述

1.一般情况下,播放的地址与网站存在SRS跨域播放问题 可以按下面方案解决此问题 在此之前,千万一定不要执行编译!

#cd srs/trunk

#vi src/app/srs_app_http_stream.cpp

在w->header()->set_content_type("video/x-flv");下一行添加代码

w->header()->set("Access-Control-Allow-Origin","*");

然后直接编译安装SRS

12.1.2测试步骤

. 推流rtmp://10.10.14.103:1935/live/livestream

./objs/srs -c conf/srs.conf

http://10.10.14.103:8080/players/srs_player.html播放

http://10.10.14.103:8080/ live/livestream.flv

12.1.3涉及的内容

参见上文从SRS服务器拉HTTP-FLV流