互动直播的视频录制与合成—支持多人离线重入

27次阅读

共计 3482 个字符,预计需要花费 9 分钟才能阅读完成。

实现的效果图:

上图合成了 2 个人视频,中途有 1 个人先离开之后又重新加入了房间。
一、业务场景
业务场景是这样的:多个用户(2- 4 人)直播的视频,合成为一个视频,这期间要满足 2 个条件:首先,录制途中可能有一个或多个用户不定次数的离线、重进(网络差和人为操作)的情况;第二,要保证合成的视频和录制的效果是一样的必须是同步的(不能出现多个视频时间对不上的情况)。
基于以上两个条件来说,程序的实现难度还是有的,不过还好,笔者已经找到了一些解决方案,下面来和大家分享一下。
二、解决方案概述
方案一:使用腾讯云互动直播和在线录制,不过腾讯云录制的视频 mp4 格式,每 30 分钟分为一个文件,也就是说录制途中可能出现多个视频,而且录制之后转码的时间不确定,所以录制之后,要借助数据库的记录信息和 ffmpeg 做多个视频的合成。
方案二:使用声网的互动直播和服务器录制,缺点是声网并不提供在线录制功能,需要用户自己部署录制服务器,优点是声网录制的视频是完整的,并在录制结束之后可以立马查看视频。
以上两种方案,都支持一定时间内(5 分钟也可以自己设定),一个或多个人离开房间之后有重新进入房间的情况,并且不会影响视频的录制,而且视频也是同步的,不能出现多个视频时间对不上的情况。
三、腾讯云录制方案
本文主要讲的是视频录制与合成,所以关于互动直播的内容,并不属于本文讨论的范围,有对互动直播感兴趣的同学可以点击链接查看,腾讯实时音视频参考地址:http://t.cn/EquSeRo
腾讯云的在线录制还是比较简单的,可以使用 Web API 的方式实现,参考文档:https://cloud.tencent.com/doc… 调用接口传参即可,如果是开启了自动录制功能,连调用 web api 都省了,但是灵活性相对低很多,并且这也是收费的,关于收费的细则详见下文,所以建议手动调用开启录制。
本节重点来看 ffmpeg 合成视频的功能,以下是关于 ffmpeg 的介绍
官网:http://ffmpeg.org/
下载地址:https://ffmpeg.zeranoe.com/bu…
中文翻译文档:https://www.bookstack.cn/read…
ffmpeg 的使用还是很简单的,通过上面连接只需要把 ffmpeg 下载好就可以了,然后通过调用命令就可以合成视频了。因为我们是 mp4 格式的视频(至于为什么是 mp4 的,因为业务的需求,还要和其他功能衔接,所以必须是 mp4 格式的),所有就不能直接使用 ffmpeg 的命令,一次性的合成多个 mp4 文件了,但是可以通过把 mp4 文件转换成 ts 格式文件,再一次性的合成多个视频并转换视频为 mp4 的。
具体步骤如下:
1、打开命令行,切换到 ffmpeg 的安装目录;
2、使用命令,把多个 mp4 文件分别转换成 ts 格式文件:ffmpeg -i 1.mp4 -vcodec copy -acodec copy -vbsf h264_mp4toannexb 1.ts;
3、使用命令,把转换好的多个 ts 文件进行拼加,并转换视频格式为 mp4:ffmpeg -i “concat:1.ts|2.ts|3.ts” -acodec copy -vcodec copy -absf aac_adtstoasc output.mp4;
这样就完成了视频的合成。当然在合成视频之前先要把腾讯云的视频下载下来,合成视频之后可以选择把视频再上传到腾讯云的云端。
四、声网录制方案
和腾讯云相同,声网的互动直播集成文档:http://t.cn/Eq3RpOS 本节重点介绍视频录制合成功能。
声网的录制服务器要自己配置,首先需要买一个 Linux 服务器,目前只支持 Linux 哦,然后设置服务器,如下所述。
服务器配置
1、Ubuntu 12.04+ x64 或 CentOS 6.5+ x64
2、GCC 4.4+(一般 linux 系统都会预装,使用命令:gcc - v 查看版本号)
3、公网 IP
4、域名“qos.agoralab.co”加入白名单
5、NodeJS 8.9+
服务器的录制程序可以使用 NodeJS 来实现,这对于开发者来说也是一件好事,毕竟减低了程序部署的门槛,它实现的原理是使用:NodeJS 的 Express 框架来实现 Restful API 的调用,NodeJS 在调用 C ++ 的插件,通过插件再调用 C ++ 的录制 SDK,完成整个流程的,如下图所示:

接下来就正式进入服务器部署了,步骤如下:
1、下载 NodeJs 部署程序,访问:https://github.com/AgoraIO/Ba…,部署到你的服务器;
2、下载录制 SDK,访问:http://t.cn/Eq17cLU;
3、解压录制 SDK 并拷贝到 NodeJS 部署目录的 record/src/sdk 目录;
4、安装 node-gyp,使用命令:npm install -g node-gyp;
5、打开终端,进入 Agora-Restful-Recording-Nodejs/record 目录,运行 sh 文件 sh build.sh,编译 C ++ 的调用,运行成功之后可以看到“agorasdk.node”文件;
以上操作,也可查看官网文档(英文的):http://t.cn/Eq1ZncK
完成以上操作之后,真正的坑才在等着你,下面来说重点了。
【程序部署的坑】
执行完以上操作之后,需要下面的两项设置,才能正常的录制视频:
1、设置 Linux 文件夹权限:chmod -R 777 /{你的目录}/Agora-Restful-Recording-Nodejs;
2、设置你的互动直播客户端为直播模式,因为 NodeJS 里面是写死的直播模式,而客户端的互动直播默认的是非直播模式,所以需要设置:setChannelProfile(1) 和 setClientRole(1),否则录制的视频是纯色的背景图,无内容;
恭喜你经过以上的配置,终于可以运行视频录制了,到在开始之前你需要先运行 NodeJS 的 Express 项目:
1、使用终端,切换到 Agora-Restful-Recording-Nodejs/server 目录,执行 npm install 安装;
2、使用终端 node app.js 运行项目;
这个时候使用 Web API 的方式就可以完成调用了。
开始录制,调用如下:

结束录制,调用如下:

【使用小技巧】
声网的 appid 参数配置在程序中,不要通过参数传递,降低账号被盗用的风险
有了以上的步骤就完成了程序的录制,不过还有更多的坑在后面等着你,笔者整理了使用中的坑,如下。
【使用中的坑】
1、录制的视频不能直接返回 mp4 地址,需要遍历文件夹路径找到 mp4 格式文件返回。
2、设置允许离线时长,此项目默认只有 10 秒,时间太短了,最好要设置 5 分钟,通过设置 Agora-Restful-Recording-Nodejs/record/src/agora_node_ext/agora_node_recording.cpp 文件中的 config.idleLimitSec=300 修改运行离线时长为 5 分钟。
3、mp4 文件有时不会立马产生,会出现偶尔遍历文件夹,mp4 文件还没产生的情况,这个时候直接返回给调用端会导致程序缺陷,所有要创建一个循环检测计数器,检测 mp4 文件产生之后再返回给调用端,保证程序的稳定性。
五、总结
上文分别介绍了两种视频录制合成的技术,下面我们对两种合成技术做一个对比,方便开发者选择更适合自己的技术方案。
对比一:功能对比
腾讯云的在线录制刚开始使用方便,但录制 mp4 格式视频会产生多个视频文件,所以后期的处理比较麻烦。而声网因为没有自己的在线录制功能,所以需要开发者自己配置录制服务器和保存视频,但录制视频完整(不会拆分为多个视频),支持多个视频的自动合成和离线重入。
对比二:服务器成本对比
1、腾讯云的收费分为三部分:第一部分,每路推流费用 60 元 / 路,按最高并发的路数计算,比如我们上个月的高峰期是一百个人同时在线,那推流的费用就按最高分并发的 100*60=6000 元;第二部分,云视频存储的费用,这部分空间的费用是很少的;第三部分,视频合成的服务器费用。
2、声网只需要录制服务器的费用,成本相对可控,,且费用不高,比如阿里云的云服务器,16 核 + 32G 内存 + 35 兆固定宽带每月才 3200 元。
服务器成本而言,声网的服务器成本低于腾讯云的服务器成本。
看到这里相信开发者已经有了自己的选择,但不管怎么,希望本文能给大家一个解决视频录制和合成的思路,也希望大家在具体使用的时候能避开文章提到的一些坑。
最后
关注作者公众号,了解后续更多精彩内容:

如果觉得本文对你有帮助,欢迎转发到朋友圈或直接分享给你的朋友。

正文完
 0