EasyDarwin开源流媒体服务器Golang版本:服务端录像功能发布

EasyDarwin开源流媒体服务器(www.easydarwin.org)现在使用Go版本实现了。最新的代码提交,已经支持了推流(或者拉流)的同时进行本地存储。

本地存储的原理,是在推流的同时启动ffmpeg作为一路Client来做存储。ffmpeg在demux和mux的工作方面已经十分成熟,我们没必要再重复发明轮子。因此这种做法十分取巧而且简单有效,也不会侵入原来的代码架构。如下图所示:


RTSP摄像机EasyDarwin本地存储推流使用ffmpeg进行拉流和存储RTSP摄像机EasyDarwin本地存储

使用方法如下:

安装ffmpeg。

EasyDarwin使用Ffmpeg进行本地存储,所以首先需要安装ffmpeg才能继续。可在ffmpeg官方下载链接选择适当的平台来下载。
在这里插入图片描述
下载完成后,得到一个zip压缩包,解压出来。我解压之后的目录为Downloads/ffmpeg-20180719-9cb3d8f-macos64-shared/

配置存储

EasyDarwin的配置文件,默认为与可执行文件同目录的EasyDarwin.ini文件。EasyDarwin也支持使用用户指定的配置文件,这样很方便在调试环境和生产环境来切换。自定义配置文件如何配置,参考我的另一篇文章的说明。

我们使用文本编辑器打开EasyDarwin.ini,内容如下:

[http]
port=10008
default_username=admin
default_password=admin

[rtsp]
port=554
timeout=28800
gop_cache_enable=1
save_stream_to_mp4=0
ffmpeg_path=
mp4_dir_path=

其中,rtsp小结里面,有如下几项是事关存储的,我们要做些修改:

  1. save_stream_to_mp4表示是否开启本地存储。1表示开启,0表示不开启。我们改成1即可
  2. ffmpeg_path表示ffmpeg的可执行文件的路径。即上一步从ffmpeg下载安装后的路径,如我的mac上的路径为/Users/apple/Downloads/ffmpeg-20180719-9cb3d8f-macos64-shared/bin/ffmpeg
  3. mp4_dir_path表示录像文件的存储目录。设置为一个存在的可读可写目录即可。比如我设置为/Users/apple/Downloads/EasyDarwinGoMP4
  4. 启动EasyDarwin服务,可看到有这样一句[EasyDarwin] 2018/11/17 12:45:35 rtsp-server.go:67: Prepare to save stream to local....输出日志,表示配置本地存储成功。
测试验证

我们可以安装一个手机端的EasyPusher来方便地测试推送(EasyPusher是手机端的一个RTSP推流器,详见:https://github.com/EasyDarwin/EasyPusher)。

  1. 我们设置EasyPusher端的推流地址为EasyDarwin的服务器地址,服务器地址一般为RTSP://SERVER_IP 这里使用了RTSP协议的默认端口554。如果不是很清楚服务器IP,可以在服务器的打印日志里面看到,如下:
    rtsp server start --> rtsp://192.168.0.108
    EasyPusher的推流地址设置为:
    在这里插入图片描述

  2. 确保手机端和服务器端在同一个网络下,我们启动手机端EasyPusher的推送。可在服务器控制台看到如下日志:

Input #0, rtsp, from 'rtsp://192.168.0.108:554/439622.sdp':
  Metadata:
    title           : EasyDarwin
    comment         : EasyDarwin
  Duration: N/A, start: 0.000000, bitrate: N/A
    Stream #0:0: Video: h264 (Baseline), yuv420p(tv, unknown/bt470bg/unknown, progressive), 360x640, 18.67 tbr, 90k tbn, 180k tbc
    Stream #0:1: Audio: aac (LC), 8000 Hz, mono, fltp
Output #0, mp4, to '/Users/apple/Downloads/EasyDarwinGoMP4/439622.sdp/20181117150909.mp4':
  Metadata:
    title           : EasyDarwin
    comment         : EasyDarwin
    encoder         : Lavf58.17.101
    Stream #0:0: Video: h264 (Baseline) (avc1 / 0x31637661), yuv420p(tv, unknown/bt470bg/unknown, progressive), 360x640, q=2-31, 18.67 tbr, 90k tbn, 90k tbc
    Stream #0:1: Audio: aac (LC) (mp4a / 0x6134706D), 8000 Hz, mono, fltp
Stream mapping:
  Stream #0:0 -> #0:0 (copy)
  Stream #0:1 -> #0:1 (copy)
Press [q] to stop, [?] for help
frame=   38 fps=0.0 q=-1.0 size=       0kB time=00:00:02.60 bitrate=   0.1kbits/s speed=5.21x    
frame=   48 fps= 47 q=-1.0 size=       0kB time=00:00:03.15 bitrate=   0.1kbits/s speed=3.07x    
frame=   57 fps= 37 q=-1.0 size=       0kB time=00:00:03.71 bitrate=   0.1kbits/s speed=2.39x    
frame=   67 fps= 33 q=-1.0 size=       0kB time=00:00:04.17 bitrate=   0.1kbits/s speed=2.03x    
frame=   77 fps= 30 q=-1.0 size=       0kB time=00:00:04.70 bitrate=   0.1kbits/s speed=1.83x    
frame=   86 fps= 28 q=-1.0 size=       0kB time=00:00:05.20 bitrate=   0.1kbits/s speed=1.69x    
frame=   96 fps= 27 q=-1.0 size=     256kB time=00:00:05.74 bitrate= 365.2kbits/s speed=1.59x    
frame=  106 fps= 26 q=-1.0 size=     256kB time=00:00:06.28 bitrate= 333.7kbits/s speed=1.51x    
frame=  115 fps= 25 q=-1.0 size=     256kB time=00:00:06.78 bitrate= 309.3kbits/s speed=1.45x    
frame=  126 fps= 24 q=-1.0 size=     256kB time=00:00:07.37 bitrate= 284.4kbits/s speed=1.41x    
frame=  135 fps= 23 q=-1.0 size=     256kB time=00:00:07.85 bitrate= 266.9kbits/s speed=1.36x    

这些日志持续在打印,表示ffmpeg已经启动了存储功能。

  1. 我们在手机端停止推送,然后可看到服务器端打印如下日志,表示mp4文件存储成功。
[EasyDarwin] 2018/11/17 15:13:30 rtsp-server.go:183: session[pusher][TCP][/439622.sdp][VJ4vgafiR] end, now pusher size[0]
[EasyDarwin] 2018/11/17 15:13:30 rtsp-server.go:104: prepare to SIGTERM to process:&{11662 0 0 {{0 0} 0 0 0 0}}
[EasyDarwin] 2018/11/17 15:13:30 rtsp-server.go:109: delete ffmpeg from pull stream from pusher[session[pusher][TCP][/439622.sdp][VJ4vgafiR]]
frame= 4864 fps= 18 q=-1.0 Lsize=   15348kB time=00:04:21.37 bitrate= 481.0kbits/s speed=0.97x    
video:14730kB audio:524kB subtitle:0kB other streams:0kB global headers:0kB muxing overhead: 0.615662%
Exiting normally, received signal 15.
[EasyDarwin] 2018/11/17 15:13:40 pusher.go:258: session[player][UDP][/439622.sdp][Y-4vgaBig] end, now player size[0]
  1. 打开之前设置的存储文件的目录,我这里是/Users/apple/Downloads/EasyDarwinGoMP4,可看到生成了以推流ID命名的一个文件夹:439622.sdp,这个文件夹下面有生成了以时间命名的MP4文件
    在这里插入图片描述
  2. 测试下这些mp4文件是否可正常播放。

至此,EasyDarwin的录像存储功能已经给大家介绍完了。EasyDarwin是一款开源的RTSP流媒体服务器。我们后续将会持续迭代,增加一些有趣的功能,比如录像查询与回放等等。欢迎大家关注和使用,地址:https://github.com/EasyDarwin/EasyDarwin

EasyDarwin官方网站:www.easydarwin.org

posted @ 2018-11-25 19:46  Babosa|EasyDarwin  阅读(1057)  评论(0编辑  收藏  举报