ffmpeg视频截取时DTS乱序导致无法截取的问题

最近在一个需求中,我需要批量从hls视频中截取出10s的视频,发现有很小概率会截取失败,

视频截取的完整命令如下:

bash 复制代码
ffmpeg -i https://file.xindoo.xyz/utopia-file/local/video/605d3af0a9cb469c91fbb309422e6672/playlist.m3u8 -r 15 -ss 19 -t 10.0 -b:v 4096k -vcodec libx264  12345.mp4

开始以为是hls中的视频片段有问题,后来和同事一起排查发现,所有失败的情况下,执行ffmpeg命令截取时都会报[mov,mp4,m4a,3gp,3g2,mj2 @ 0x7fd6fa008780] DTS 0 < 1986554 out of orderspeed=0x [hls @ 0x7fd6fa004a40] DTS 0 < 1986554 out of order ,顺着这个信息我们发现但凡失败的,都是我们在m3u8里拼接了另外一个视频的部分片段导致的。

要理解这个问题,我们首先需要解释下什么是DTS, DTS (Decoding TimeStamp)这是视频或音频帧应当被解码的时间。这个时间戳也是基于播放起始点的,告诉播放器什么时候应该开始解码这个帧。用大白话讲 DTS就是视频每一帧相对于这个视频开始事件点的位置。

我们在业务中为了能灵活且低成本获取任意时间段之间的视频,选择将原始视频切分一个个ts片段,按需选取后重新生成一个m3u8文件。 因为原始视频不是连续录制,所以就有一定的概率出现A视频的末尾和B视频的开始拼接在同一个m3u8中的可能。在这种情况下,A视频末尾一帧的DTS和B视频首帧的DTS肯定是不连续的,截取时就会报"DTS 0 < 1986554 out of order",最终截取失败。

如何解决?我尝试了很多种参数,比如-vsync、-fflags +igndts,甚至切换了ffmpeg版本,均无法解决。最后还是用蠢办法,先将hls格式的视频保存成mp4然后从mp4中截取,绕开这个bug。具体的实现就是将上面的一条命令拆分成如下两条:

bash 复制代码
# 先转存成mp4文件
ffmpeg -i https://file.xindoo.xyz/utopia-file/local/video/605d3af0a9cb469c91fbb309422e6672/playlist.m3u8 -c:v copy temp.mp4
# 然后从mp4文件中截取视频 
ffmpeg -i temp.mp4 -r 15 -ss 19 -t 10.0 -b:v 4096k -vcodec libx264  12345.mp4
相关推荐
王家视频教程图书馆27 分钟前
vue3从本地选择一个视频 展示到视频组件中
前端·javascript·音视频
新科技事物1 小时前
AI编曲软件帮原创音乐人,用清唱歌词的音频快速做出专业的歌曲编曲伴奏
人工智能·音视频
新科技事物2 小时前
AI编曲软件提升出歌效率,原创音乐人凭清唱歌词的音频快速作编曲伴奏成歌
人工智能·音视频
softbangong4 小时前
899-批量视频处理工具
ffmpeg·格式转换·批量处理·音频提取·视频处理工具·视频截取
AI科技4 小时前
清唱歌词的音频直接用,原创音乐人用AI编曲软件直接生成完整歌曲的编曲伴奏
人工智能·音视频
wefly20175 小时前
M3U8 播放调试天花板!m3u8live.cn纯网页无广告,音视频开发效率直接拉满
java·前端·javascript·python·音视频
凉拌菜7 小时前
医用录像机在手术影像系统中的作用:视频采集与存储架构
音视频
WJSKad12357 小时前
[特殊字符] Mimi音频神经网络编解码器:高保真声音处理的突破
人工智能·神经网络·音视频
凉拌菜7 小时前
手术摄像系统的视频延迟是如何产生的?从采集到网络传输的技术解析
网络·音视频·医疗视频·4k视频·术野摄像机
ai产品老杨8 小时前
源码交付与异构算力破局:基于GB28181/RTSP的Docker化AI视频平台架构实战
人工智能·docker·音视频