业务述求

	需要在WEB端实时查看现场的视频监控(公司选型的是大华摄像机)

技术方案选型

1.  ffmpeg通过rtsp协议拉取视频流
2.  使用vlc media player 组件拉取视频流,在web端显示
3.  使用h5Stream在线对视频流拉取

实现大方向

  1. 把局域网内的摄像头地址做穿刺暴露给外网,并更具响应的视频拉取协议映射好端口
  2. 安装相应的组件,对相应视频流进行拉取
  3. 在WEB对通过中间件中转,显示到页面

实现细节

局域网内摄像头配置

公司选型的大华摄像机,所有摄像机出厂统一IP是192.168.1.108 
这个IP是可变的,可配置,但是前提这个IP可以访问到摄像头才允许更改

在地址栏输入192.168.1.108,第一次登陆默认账号密码都为admin,默认端口37777,第一次登陆会提醒你更改账号密码,记得不要忘记,后面视频拉取的需要用到,进入摄像头更具自己需要做个性化的配置。
相关协议端口开放如下:
在这里插入图片描述

摄像头的ip地址穿刺

  1. 登录公司路由器,做端口映射
    在这里插入图片描述
  2. 使用花生壳做穿刺。
    在这里插入图片描述

使用路由器映射的方法,需要拿到路由器的账号密码,这个得跟公司的运维沟通下。
用花生壳做穿刺,会免费赠送一个域名,但是端口是不固定的,如果配置固定的端口,花生壳需要书费收费

在百度上输入本地IP会出现公司路由的外网IP。
测试下两种方式是否可以通过外网IP来访问。

拉取视频流

我选用的的是rtsp协议来拉取视频流,大华摄像机的rtsp地址格式如下:

rtsp://[账号]:[密码]@[IP]:[端口]/cam/realmonitor?channel=1&subtype=0
channel=1,此属性值对应渠道。subtype=0对应使用主码流还是辅码流

不管大华摄像机也好,还是海康威视摄像机,他们官网都提供本地局域网内的摄像头管理软件。进入官网,导航找到技术支持,里面有工具软件。比如大华的可以用smartPss,海康威视的有iVMS,视频流通过可以通过多个渠道来传输,所以channel要和本地软件中输出通道一致

比如的本地地址:rtsp://admin:Aa517518@192.168.0.108:554/cam/realmonitor?channel=1&subtype=0
本地摄像头IP地址做穿刺后,把账号密码换成公网的ip和端口即可。

使用h5Stream拉取视频流

h5Stream网上的配置文档很多,不做一一赘述,其主要配置文件为:
conf目录下的h5ss.conf文件。
在这里插入图片描述
我这里用的是rtsp协议,根据自己的需要配置,一般配置一个空闲的端口即可。
在这里插入图片描述
在web端的显示,在h5stream安装目录里, www目录下有相关的使用样例。

优点:配置简单,实时视频同步延迟小,画面清晰。firefox,chrom,ie都可以使用
缺点:web页面操作相对复杂,在使用多个摄像头,配置清单驳长,h5stream为收费软件,h5stream为收费软件,h5stream为收费软件,重要的事情说三遍原免费版,会在实时视频流播放一个小时后断流,且当前暂时没有找到破解版。我在官网找到电话,打电话过去咨询,收费是100块钱一个摄像头,具体的价格可以再谈。

vlc media player 拉取

省事儿的话先下载vlc media player安装,也可以单独下载相应的控件。
下载完成后:
在这里插入图片描述
把rtsp地址copy进地址栏,测试是否可正常显示,若不正常请检查网络是否通畅,账号密码是否正确,ip端口是否正确,通道是否一致
而在web端是根据相关的标签来的:实例如下:

<object classid="clsid:9BE31822-FDAD-461B-AD51-BE1D1C159921" codebase="http://download.videolan.org/pub/videolan/vlc/last/win32/axvlc.cab">
    <param name="autostart" value="true" />
    <param name="allowfullscreen" value="false" />
</object>

链接: vlc使用操作文档.

优点:测试简单,操作简单,WEB页面操作最简单,视频清晰度无损,延迟级小。
缺点:谷歌只支持43版本及其更早,现在都70+版本了。火狐更直接,直接提示不支持。现在通过安装谷歌应用程序可以解决,但是面向客户的时候,客户不会使用体验版,所以注定就不会适用面就不会广

ffmpeg拉取视频流

首先ffmpeg是十分强大,且无比灵活,使用命令行来操作,相对来说就复杂的多,网上有很多安装ffmpeg介绍和ffmpeg命令介绍,这里就不做一一赘述。
ffmpeg对视频流进行拉取,转成我们需要的视频码流,比如我们使用的rtsp协议,可以转成rtmp协议或者HLS(m3u8)协议。
本文着重介绍此两种,其它的协议格式,原理上相同,只是转码后页面显示的细节不同。
ffmpeg允许截图:
在这里插入图片描述

  1. 使用HLS(m3u8)协议
    也就是ffmpeg把拉取的rtsp转成HLS的视频流。
    命令实例:
    ffmpeg -i "rtsp://admin:Aa517518@192.168.0.108:554/cam/realmonitor?channel=1&subtype=0" -c copy -f hls -hls_time 2.0 -hls_list_size 1 -hls_wrap 15 D:/workspace/nginx-1.8.1/html/hls/test.m3u8
    

NGINX并不是一定要用,只要能读取到此今天文件即可。我是通过nginx吧request请求,定向到此文件,当然web项目比较灵活,可以通过web来做访问。
生成的文件如下:
在这里插入图片描述
静态资源只要支持hls协议,使用今天资源,访问test.m38u文件即可
引入video.js,我使用的是7.4.1

<video id="test_video" class="video-js vjs-default-skin vjs-big-play-centered" controls autoplay width="960" height="400">
    <source src="http://192.168.0.118:1935/hls/test.m38u" type='rtmp/flv'>
</video>

缺点:此方法对网络依赖要求比较高,延迟高,容易卡顿

  1. rtmp协议
    命令样例:
    ffmpeg -rtsp_transport tcp -i "rtsp://admin:Aa517518@192.168.0.108:554/cam/realmonitor?channel=1&subtype=0" -f flv -r 25 -s 1280*720 -an "rtmp://192.168.0.118:1935/hls/mystream"
    
    其中把rtsp视频流转成rtmp视频流,通过video.js 直接在页面播放
    <video id="test_video" class="video-js vjs-default-skin vjs-big-play-centered" controls autoplay width="960" height="400">
    	<source src="rtmp://192.168.0.118:1935/hls/mystream" type='rtmp/flv'>
    </video>
    

使用ffmpeg优缺点:
优点:谷歌火狐IE都可以用。
缺点: ffmpeg很强大,使用命令很灵活,很多细节问问需要琢磨,比如清晰度的问题,比如帧数的问题。
ffmpeg比h5stream和vlc使用上确实麻烦许多,而且清晰度不如以上两种,延迟相对也高一下。
需要建立相对完善的管理机制,因为全部使用命令,在客户页面关闭视频流时,后台还在不停的拉取视频流,造成极大的资源浪费。

不足与思考

  1. 不足
    单个的视频播放,注定应用面相对狭窄,相当于只写了一半的功能,在很多引用场景单个摄像头是不能满足业务需求的,一般需要拉取多个视频流,这个就很需要好好的思考的。
    多个摄像头,如果不在同一个局域网,那么拉取视频流占用较大的资源就无法避免
  2. 思考
    如果在同一的局域网,使用本地的工具,比如电视墙功能,组播功能,在多个镜头信息直接完成一个视频流拉取多个摄像头信息
    如果是不同的局域网,那么就需要使用ffmpeg的组播功能,vlc和h5stream的支持并不是很友好
    视频流并不是24小时拉取,如果使用ffmpeg的话,在空闲时间并不能主动停止拉取,在WINDOWS下也很难精确的停止某个视频流的拉取进程,在linux下回相对好一些,可以shell脚本找到相对于的pid并KILL
Logo

致力于链接即构和开发者,提供实时互动和元宇宙领域的前沿洞察、技术分享和丰富的开发者活动,共建实时互动世界。

更多推荐