最近在工作中遇到一个ffmpeg的坑,特此记录下。我们在工作中,有个需求是将分段存储的视频拼接成一个完整的视频,发现使用ffmpeg拼接后视频时长不对。举个列子,我用ffmpeg将4个半小时的mp4视频拼接后,得到的视频长度远超过2小时,观看后发现在视频的连接点,会出现长时间的卡顿,导致最终视频时间超长。

在ffmpeg官方文档Concatenating media files中,介绍了三种视频拼接的方式,分别如下:

1. 针对同种编码的视频

可以将所有视频文件名列到一个文本文件中,格式如下:

file '/path/to/file1.wav'
file '/path/to/file2.wav'
file '/path/to/file3.wav'

然后使用命令ffmpeg -f concat -safe 0 -i mylist.txt -c copy output.wav 完成对视频的拼接,这种方式也是拼接最快的方式。大致原理是直接将视频首位相接,不会涉及到编解码,整体执行的时间主要是磁盘IO的时间,我们实测100个文件,拼接成一个5g大的长视频,也只需要几十秒的时间。
但是,这种拼接方式有自己的局限,首先它只能拼接相同编码的视频,比如都是mp4。而且,这种方式也有bug,拼接mp4视频文件得出来的视频时长不对,就是我开头所说的问题,因为这个bug我们差点改业务需求。不过这个bug可以绕过去,就是将所有mp4文件先转成ts文件,然后对ts文件拼接,拼接ts视频不会出现这个bug。

mp4转ts文件的命令如下:

ffmpeg -i input.mp4 -c:v copy ouput.ts

因为mp4转ts的过程也不涉及到视频编解码,所以也很快,我们也是用这种方式绕开了bug,完成了整个需求。 其实视频拼接还有两种方式,对我们都不太合适,后续会说到。

2.使用concat协议

ffmpeg -i "concat:input1.ts|input2.ts|input3.ts" -c copy output.ts

这个方式我们没有具体测试,貌似不会涉及到编解码,所以应该也挺快的,但网上说这个命令执行的条件也比较苛刻,也不推荐使用。我们没有用的原因单纯是因为需要拼接上百个视频,这种方式需要拼一个非常长的命令行。

3. 使用Concat filter

ffmpeg -i input1.mp4 -i input2.webm -i input3.mov -filter_complex "[0:v:0][0:a:0][1:v:0][1:a:0][2:v:0][2:a:0]concat=n=3:v=1:a=1[outv][outa]" -map "[outv]" -map "[outa]" output.mkv

这种使用方式还是偏复杂,具体可以参考下官方文档Concatenating media files。该方法的优点就是效果稳定、且支持不同格式的视频,所以也是最推荐的视频拼接方式。但缺点也很明显,需要涉及到视频的编解码,所以会非常耗性能,就是因为性能问题,我们也抛弃这种方案了。

说下我们实测的数据,我们用通用服务器,拼接60分钟的视频需要20-30分钟(和服务器配置有关),看着还行,但我们每天有数千小时的视频需要拼接,需要几十台服务器24小时满负荷工作才能完成,对于我们当下来说成本还是偏高。 我们也委托别人试了使用GPU加速的拼接效果,确实快了很多,1小时视频1分钟内就可以完成。

总结

我们当前没有GPU资源,所以当下还是选择了使用第一种视频拼接方式,第一种方式目前最大的瓶颈只在于网络IO(视频下载上传)上,但这种方案也限制了我们只能完成对视频的拼接,无法调整其分辨率以达到降低存储的目的。长期来看我们肯定得考虑使用硬件加速的方式完成超大视频量的处理。

使用ffmpeg拼接视频踩坑记录相关推荐

  1. vue项目中将视频链接分享至推特的解决方法及踩坑记录

    vue项目中将视频链接分享至推特的解决方法及踩坑记录 将动态改变的视频链接分享至推特,并希望能直接在推特上播放视频的需求实现方法及踩坑记录 如果只要将文本或链接分享到推特,不需要推特识别图片/视频等媒 ...

  2. 日常踩坑记录-汇总版

    开发踩坑记录,不定时更新 心得 RTFM 严谨的去思考问题,处理问题 严格要求自己的代码编写习惯与风格 注意 单词拼写 20200207 mybatis plus 自带insert插入异常 sql i ...

  3. mybatis学习与踩坑记录

    mybatis resultmap高级映射 应用场景:如果sql查询的列名和pojo的属性名不一致,可以使用resultMap将列名和pojo的属性名作一个对应关系,就可以映射成功了.(如果返回值为i ...

  4. 【学习记录】QT5界面设计的踩坑记录

    学习记录:QT5 界面设计的踩坑记录 前言 一.Qlabel显示视频与图片 1. 图片显示 1.1 显示格式 1.2 label随界面缩放 1.3 界面刷新 2. 视频显示 二.常见控件的StyleS ...

  5. 【威联通QNAP】TS-216折腾踩坑记录(更新于22.11.22)

    本篇博客记录了我使用威联通ts216的折腾记录.nas购入于2022年双11,京东自营 关于系统初始化等内容不做记录,这部分网上可以找到很多教程,只要是威联通,方法都是一样的 初始化参考视频 [村雨] ...

  6. Win10+yolov5 踩坑记录

    Windows10下配置yolov5环境 踩坑记录 起因随笔 基本的环境要求 yolov5各代码作用 踩坑的Package windwos下torch和torchvision的安装 windows下p ...

  7. 微信客服机器人(踩坑记录、SpringBoot、企业微信)

    微信客服机器人(踩坑记录.SpringBoot.企业微信) 转载请注明出处:https://www.jjput.com/archives/wei-xin-ke-fu-ji-qi-ren 总体流程 当有 ...

  8. 【STM32+机智云】机智云手机APP点灯实验踩坑记录

    [STM32+机智云]机智云手机APP点灯实验踩坑记录 一.实验背景 因为项目开发需要用到云平台,所以开始学习机智云平台,听说机智云比较容易入门,还有手机APP.因此开始了踩坑之旅,一切的一切开始于一 ...

  9. Nvidia Jetson TX2 详细刷机教程及踩坑记录(Jetpack4.5.1,python3.6,torch1.6,torchvision0.7)

    最近接触到了Nvidia Jetson TX2这块开发板,想入手测试一下自己的深度学习模型,因此和TX2的故事开始了! 前言 本人刷机多次,尝试各种大小坑: 自带系统搭建环境:刚开始不想刷机,就自己手 ...

最新文章

  1. VS2005 / windows sdk7.1配置
  2. java 端写的list 前端页面获取方法
  3. java中的几种对话框_Java中弹出对话框中的几种方式
  4. hdu2489-DFS+最小生成树
  5. 自定义控件-侧边菜单SlidingMenu(滑动菜单)
  6. 关于snowflake算法的几个问题
  7. vi测试仪维修成功率高吗?_老客户维护难,转介绍更难,这16个问题你做到了吗?...
  8. Java Web实战篇-轻松提高千万级数据库查询效率
  9. centos6.5安装mysql-udf-http日记
  10. python发送soap报文_python处理SOAP API
  11. lecture9-提高模型泛化能力的方法
  12. Flash地址空间的数据读取——STM32
  13. matlab里det函数的神奇bug
  14. Android运用手机多媒体
  15. java实现区块链中的区块hash难度系数的设计
  16. Chap.17 总结《CL: An Introduction》 (Vyvyan Evans)
  17. 三网折扣话费充值接口文档
  18. Leetcode典型题解答和分析、归纳和汇总——T101(对称二叉树)
  19. c++内存释放的几种方法
  20. php mvc例子,PHP_ThinkPHP的MVC开发机制实例解析,ThinkPHP是目前国内应用非常广 - phpStudy...

热门文章

  1. unity替换shader方法
  2. 以transformer为基础的Bert和GPT
  3. 最大比例(辗转相除)
  4. 沪深股票历史财报数据查询系统网络共享版
  5. 2.9亿元信托财产“原状返还” ,信托公司“去通道”还要走多久?
  6. Vue 和 jQuery 两者之间的区别是什么?
  7. SAN和NAS有什么区别
  8. BaziPickView 八字时间选择器、
  9. 【日语】流行日语【二】
  10. Java判断某特殊字符串结尾的2种方法