ffmpeg拉取rtsp网络视频流报错解析

embedded/2024/9/25 5:08:27/

在使用ffmpeg调用api方式对一个rtsp网络视频流拉流播放时,应用程序出现了一些错误提示,并且拉流播放的画面也出现了一些马赛克的现象。所以这里便对应用程序所产生的错误提示进行了详细的研究和分析。这里将分析结果贴在下面,若其他朋友遇到类似的错误,供参考。

[rtsp @ 0x560bbad10b00] max delay reached. need to consume packet-------------该报错说明ffmpeg接收端的缓冲区已满,达到最大延迟限制,接收端无法及时处理这些视频帧
[rtsp @ 0x560bbad10b00] RTP: missed 152 packets-------丢失了部分rtp协议数据包,造成的影响是可能是马赛克 卡顿或者跳帧
Invalid UE golomb code--------解码失败或者部分失败
[h264 @ 0x560bbad513c0] cbp too large (3199971767) at 86 31-------[h264 @ 0x560bbad513c0]: 表示这是 H.264 解码器报告的错误,后面的十六进制数是解码器实例的内存地址。"cbp too large (3199971767)": CBP 代表 Coded Block Pattern,这个值异常大。"at 86 31": 可能表示错误发生在第 86 帧的第 31 个宏块(或者是其他相关的位置信息),问题原因可能是解码器版本与编码器版本不匹配或者编码器生成了不符合h264的数据流
[h264 @ 0x560bbad513c0] error while decoding MB 86 31-----[h264 @ 0x560bbad513c0]: 表示这是 H.264 解码器报告的错误,后面的十六进制数是解码器实例的内存地址。"error while decoding MB 86 31": 表示在解码第 86 个宏块(Macroblock)的第 31 个子块时发生了错误。
[h264 @ 0x560bbad513c0] concealing 4403 DC, 4403 AC, 4403 MV errors in P frame------[h264 @ 0x560bbad513c0]: 表示这是 H.264 解码器报告的信息,后面的十六进制数是解码器实例的内存地址。"concealing": 表示解码器正在尝试隐藏(或修复)错误。"4403 DC, 4403 AC, 4403 MV errors": 指出了三种不同类型的错误及其数量。"in P frame": 表明这些错误发生在 P 帧(预测帧)中。DC(直流)系数:表示块的平均亮度或色度。
AC(交流)系数:表示块内的细节和纹理信息。
MV(运动矢量):用于预测帧间运动的向量。
P 帧:预测帧,依赖于之前的 I 帧或 P 帧进行编码。
a. DC 错误:影响整个宏块的基本亮度或色度。
b. AC 错误:影响块内的细节和纹理。
c. MV 错误:影响运动预测的准确性。
错误原因:
网络传输过程中的数据包丢失或损坏。 b. 存储介质问题:
硬盘或其他存储设备上的文件损坏。 c. 编码问题:
编码器生成了不完全符合标准的比特流。 d. 解码器限制:
解码器可能无法处理某些特定的编码特性。
影响:
视频质量下降:可能会出现马赛克、模糊或冻结的画面。
运动不连贯:由于 MV 错误,可能导致运动预测不准确。
色彩或亮度异常:DC 错误可能导致整个区块的颜色或亮度出现问题。

[h264 @ 0x560bbad513c0] Increasing reorder buffer to 1-------[h264 @ 0x560bbad513c0]: 表示这是 H.264 解码器报告的信息,后面的十六进制数是解码器实例的内存地址。
"Increasing reorder buffer to 1": 表示解码器正在增加其重排序缓冲区的大小到 1。
为什么会出现这个消息:
a. 初始化过程:
解码器在开始时可能不知道需要多大的重排序缓冲区。
它可能从较小的值开始,然后根据需要增加。
b. 适应视频特性:
某些视频流可能需要更大的重排序缓冲区来正确处理帧序列。
c. 编码特性:
视频可能使用了 B 帧(双向预测帧)或复杂的 GOP(图像组)结构。
影响:
这通常不会导致任何问题或错误。
它是解码器正常工作和自我调整的一部分。
可能会略微增加内存使用。

"Increasing reorder buffer to 1" 是一个正常的操作日志,表示 H.264 解码器正在调整其内部缓冲区以更好地处理输入的视频流。这种自适应行为有助于确保视频的正确解码和流畅播放
[rtsp @ 0x560bbad10b00] max delay reached. need to consume packet-----这是与 RTSP(Real Time Streaming Protocol)流相关的一个警告或错误提示,[rtsp @ 0x560bbad10b00]: 表示这是 RTSP协议处理器报告的信息,后面的十六进制数是处理器实例的内存地址。"max delay reached": 表示达到了最大允许的延迟时间。"need to consume packet": 提示需要消费(处理)数据包。
出现这个消息的原因:
a. 处理速度不足:
接收数据包的速度快于处理数据包的速度。
可能是由于解码器处理速度慢或系统资源不足导致的。
b. 网络延迟:
网络传输延迟导致数据包堆积。
c. 缓冲区设置不当:
接收缓冲区可能设置得太小,无法容纳足够的数据包。
d. 流媒体服务器问题:
服务器可能发送数据的速度过快。
解决方法:增加缓冲区大小和最大延迟时间 -buffer_size 10240k -max_delay 5000000或者使用更快的解码器例如nvidia的解码器或者降低接收视频的质量

[rtsp @ 0x560bbad10b00] RTP: missed 3 packets
[h264 @ 0x560bbad513c0] out of range intra chroma pred mode----这是h264解码器的一个错误,[h264 @ 0x560bbad513c0]: 表示这是 H.264 解码器报告的信息,后面的十六进制数是解码器实例的内存地址。
"out of range intra chroma pred mode": 表示在帧内(intra)色度(chroma)预测模式中遇到了超出范围的值。
错误原因:
解码器遇到了一个不在预定义范围内的色度预测模式值。
这通常意味着比特流中的数据可能已经损坏或不符合 H.264 标准。
可能的原因:
视频文件损坏:
文件在传输或存储过程中可能被部分损坏。 b. 编码器错误:
编码视频的软件可能存在 bug,生成了不合规的比特流。 c. 不兼容的编码设置:
使用了解码器不支持的高级或非标准的编码特性。 d. 解码器 bug:
在某些罕见情况下,可能是解码器自身的问题。

从上面的日志可以得到结论:自己的程序出现马赛克的原因很大一部分原因是缓冲区满,达到了ffmpeg允许的最大延迟限制;也有一部分原因可能是编码器出现了一些不符合H264协议的数据流;另外也有接收端服务器性能问题。

解决方面的问题方法有以下几个方面:

  1. 降低服务端的帧率,这样数据流就会较小,可能会减少这种报错
  2. 接收解码端使用更快的解码器,例如nvida的h264_cuvid等
  3. 接收端扩大缓冲区的大小和增加最大延迟时间
  4. 调整视频源的发送分辨率和降低比特率

http://www.ppmy.cn/embedded/116454.html

相关文章

【systemctl start jenkins】启动报错问题解决

问题说明,最终是在jenkins.service中配置JAVA_HOME解决的,但是我的服务器环境中确定已经配置好了Java环境变量,并且java -version也能正常打印信息,不清楚为什么jenkins.service无法读取配置 1.环境配置说明 服务器:…

用Python提取PDF表格到Excel文件

在对PDF中的表格进行再利用时,除了直接将PDF文档转换为Excel文件,我们还可以提取PDF文档中的表格数据并写入Excel工作表。这样做可以避免一些不必要的文本和格式带来的干扰,获得更易于分析和处理的表格数据,并方便进行更多的格式设…

Altium Designer(AD)百度云下载与安装(附安装步骤)

在我们日常使用当中,Altium designer常常也被简称为AD,是一款一体化的电子产品开发系统软件,主要运行在Windows操作系统上。 我们通过Altium designer把原理图设计、电路仿真、PCB绘制编辑、拓扑逻辑自动布线、信号完整性分析和设计输出等技…

linux静态路由表

使用ip route命令临时添加静态路由表 使用ip route命令添加静态路由。例如,要添加一条到达192.168.1.0/24网络的静态路由,通过网关192.168.0.1,您可以执行: ip route add 192.168.1.0/24 via 192.168.0.1 dev enp1s0编辑网络配置…

【Python】探索 Elpy:Emacs 中的 Python 开发环境

可以短时间不开心,但别长时间不清醒。 对于使用 Emacs 编辑器的 Python 开发者来说,Elpy 是一个强大的集成开发环境(IDE),它通过整合多个 Emacs Lisp 和 Python 包,提供了一套完整的 Python 编程支持。本文…

Java项目实战II基于Java+Spring Boot+MySQL的校园社团信息管理系统(源码+数据库+文档)

目录 一、前言 二、技术介绍 三、系统实现 四、论文参考 五、核心代码 六、源码获取 全栈码农以及毕业设计实战开发,CSDN平台Java领域新星创作者,专注于大学生项目实战开发、讲解和毕业答疑辅导。获取源码联系方式请查看文末 一、前言 在当今高校…

【附答案】C/C++ 最常见50道面试题

文章目录 面试题 1:深入探讨变量的声明与定义的区别面试题 2:编写比较“零值”的if语句面试题 3:深入理解sizeof与strlen的差异面试题 4:解析C与C中static关键字的不同用途面试题 5:比较C语言的malloc与C的new面试题 6…

Bugku 渗透测试1

描  述: 甲公司邀请你对他们公司进行网络安全测试,但是甲公司只给了一个官网链接你能打到他们内网吗? 打开靶场地址 1、场景1 查看网站源码,查看最下面,得到flag。 2、场景2 根据场景1提示,下个flag网站管理员才能…