owt-server编码h264的sps pps不固定的问题

转载请注明出处:https://blog.****.net/impingo
项目地址:https://github.com/im-pingo/pingos
项目官网:https://pingos.io

问题描述

最近使用owt-server转推rtmp到媒体服务器时出现hls播放无画面的情况。
并且,使用ffplay播放hls的时候,ffplay一直有如下错误输出:
owt-server编码h264的sps pps不固定的问题
从错误输出很明显看出是pps出了错,但是rtmp播放却没有任何问题。

问题分析

后来经过对rtmp码流分析发现h264的关键帧前的sps和pps在不停地变化,每次都不一样。
但是nginx-rtmp-module在封装ts包的时候会忽略关键帧前的sps和pps,只会从avc_header中提取sps pps拼接在关键帧前,然后再封装进ts包里。问题在于owt推送rtmp数据时只会在开始的时候发送一次avc_header,推送过程中即使sps pps发生变化也不会再更新avc_header,这就导致了媒体服务器上用来封装ts包的sps和pps是失效的。
这就是为什么rtmp可以正常播放,但是hls却没有画面的原因。

问题解决

owt之所以生成的h264数据sps pps不断变化,是因为它调用webrtc库的接口来对yuv进行编码,webrtc又调用openh264库进行编码。而openh264编码h264的时候默认是不固定sps pps的。
为了解决这个问题,需要修改webrtc源码,并且重新编译webrtc库。
openh264默认使用INCREASING_ID模式,也就是每个idr帧 ,sps和pps的id都会增加。我们需要做的是改为CONSTANT_ID模式就好了。
修改代码如下:
owt-server编码h264的sps pps不固定的问题

QQ交流群:697773082

微信(cczjp1989)

owt-server编码h264的sps pps不固定的问题