使用FFmpeg+EasyDarwin搭建音视频推拉流测试环境

1. 前言

在上一篇文章《使用VS2017在win10 x64上编译调试FFmpeg(附源码和虚拟机下载)》中,我们讲解了如何搭建FFmpeg源码编译和调试环境。

调试FFmpeg,还需要搭建流媒体服务器。流媒体服务器的作用是通过网络对外提供音视频服务,包括但不限于提供视频推流、拉流服务。推流(Push):推流是指将音视频数据从本地设备(如摄像头、麦克风)通过网络上传到服务器的过程。拉流(Pull):拉流是指从直播服务器获取音视频数据并在本地进行播放的过程。

FFmpeg通过网路连接到流媒体服务器后,基于音视频协议和流媒体服务器通过交互,拉取或者推送视频数据。我们使用免费的EasyDarwin作为流媒体服务器,EasyDarwin使用简单,能够满足测试需求。

2. 安装运行EasyDarwin

2.1 下载EasyDarwin

Github:https://github.com/EasyDarwin/EasyDarwin

官网:https://www.easydarwin.org/p/easydarwin.html

官网和Github的版本都比较低,可以从下面的地址下载更高的8.1版本:

  • (关注Qt未来工程师,回复 EasyDarwin 8.1 获取下载地址)

2.2 运行EasyDarwin

双击EasyDarwin.exe,即可运行。启动界面如下所示:

根据提示,我们使用浏览器打开地址 http://192.168.0.108:10008 即可访问服务器后台。这个地址因每台电脑的网络环境而异,会不一样。后台界面如下所示:

后台可以看到推拉流信息列表、资源占用、版本等信息。

3. 使用FFmpeg推流

3.1 获取FFmpeg工具包

我们可以使用VS2017本地编译出来的FFmpeg程序,也可以使用网络上下载的FFmpeg程序工具包。FFmpeg程序工具包下载地址:

3.2 获取视频素材

在使用FFmpeg向EasyDarwin推送视频流前,我们需要准备一段本地视频文件作为素材。笔者收集了一些音视频测试素材,下载地址:

  • (关注Qt未来工程师,回复 音视频测试素材 获取下载地址)

以上音视频素材会长期更新,一些好的视频资源也会同步上传到B站。

3.3 使用FFmpeg命令推流

进入到FFmpeg程序工具包的bin目录下,在终端中执行以下命令即可实现将本地文件循环推流到EasyDarwin:

复制代码
.\ffmpeg -r 25 -re -stream_loop -10000 -i "国外街头广场行人视频-1920x1080-1分56秒.mp4"  -vcodec copy -rtsp_transport tcp -f rtsp  rtsp://192.168.0.108/test/1

注意rtsp地址中的ip要改成EasyDarwin服务器的地址,ip地址后面的路径可以自拟。推流命令执行结果如下:

查看EasyDarwin后台:

可以看到推流成功。

4. 拉流调试

4.1 使用VLC测试视频

首先我们使用 VLC 测试视频是否可以正常拉流播放。VLC是一款功能强大的免费开源播放器,纯播放器,没有任何广告,音视频开发必备。下载地址在官网:

安装完成后,打开VLC media palyer,从菜单中选择:"媒体"->"打开网络串流",在弹出的窗口中输入视频播放地址。视频播放地址从EasyDarwin后台页面中获取。如下所示:

点击播放,可正常播放,说明视频推拉流都正常,播放画面如下所示:

4.2 使用FFmpeg调试下拉流

笔者在win10虚拟机中调试FFmpeg,要保证虚拟机能ping通主机(可以使用Vmware的桥接模式)。启动win10虚拟机后,在虚拟机中进行ping宿主机测试,如下图所示。这里不详细讲解,有问题的同学可以查一下解决方法。

当然,同学们也可以将FFmpeg程序包,VLC软件,EasyDarwin软件全部放到虚拟机中运行,这样调试起来可能会更加简单,这方面大家拿到虚拟机后可以自由发挥。

打开 ffmpeg_deps.sln 解决方案。将ffmpeg项目设置为启动项目,右键ffmpeg项目,在弹出的菜单中选择"属性"。在属性对话框中,将调试命令设置为(默认已设置):

复制代码
$(OutDir)\bin\x64\$(TargetName)$(TargetExt) 

命令参数设置为:

复制代码
-i rtsp://192.168.0.108/test/1 -codec copy C:\Users\qtfuture\Desktop\1.mp4

如下图所示:

此命令的含义为,使用ffmpeg拉取地址为rtsp://192.168.0.108/test/1的视频流,保存到桌面上的1.mp4。

点击调试即可正常开始进行拉流源码调试。至此,完整的调试环境准备完成。在此基础上,读者可以自行实验推拉流等各种操作,步骤和原理和上述过程基本一致。

5. 结语

音视频系统环境稍微有些复杂,这也是学习音视频开发的难点所在。准备好完整的ffmpeg调试环境后,我们便可以尽情地探索ffmpeg内部的实现细节。后面的文章中,我们将通过源码调试对ffmpeg内部各个模块和原理进行专题研究,敬请关注。


本文原创发布于Qt未来工程师。

相关推荐
昨日之日20062 小时前
LatentSync V8版 - 音频驱动视频生成数字人说话视频 更新V1.6版模型 支持50系显卡 支持批量 一键整合包下载
人工智能·音视频
知舟不叙3 小时前
基于OpenCV实现视频运动目标检测与跟踪
opencv·目标检测·目标跟踪·音视频
allnlei5 小时前
修改FFMpeg的日志函数av_log,使其在记录日志时能显示调用该函数的位置(文件名和行号)
ffmpeg
sukalot6 小时前
window 显示驱动开发-处理视频帧
驱动开发·音视频
Sherlock Ma7 小时前
Seedance:字节发布视频生成基础模型新SOTA,能力全面提升
人工智能·深度学习·计算机视觉·aigc·音视频·扩散模型·视频生成
Everbrilliant8910 小时前
音视频之H.264/AVC编码器原理
音视频·h.264·h.264编解码·h.264帧内预测·h.264帧间预测·h.264的sp/si帧技术·h.264码率控制
s_little_monster10 小时前
【Linux开发】海思摄像头内部视频处理模块
linux·运维·经验分享·学习·音视频·嵌入式开发·海思
vfvfb19 小时前
视频音频去掉开头结尾 视频去掉前n秒后n秒 电视剧去掉开头歌曲
音视频·批量去掉视频开头·批量去掉崇·去掉mp3开头几秒·批量去掉视频结尾歌曲
Coovally AI模型快速验证20 小时前
SLAM3R:基于单目视频的实时密集3D场景重建
神经网络·算法·3d·目标跟踪·音视频
no_work1 天前
深度学习小项目合集之音频语音识别-视频介绍下自取
pytorch·深度学习·cnn·音视频·语音识别·梅卡尔