FLV直播流起播异常慢

简介: 本文记一次阿里云FLV直播流起播慢的案例排查,分析过程中同步介绍了Aliplayer、第三方Flash播放器、FFplay播放器的使用和测试分析,同时结合通过直播控制台的实时监控服务去分析直播流的特性,希望可以对遇到此类问题时有更多的思路和启发。

案例现象-H5播放FLV起播慢

阿里云视频直播服务提供了RTMP/FLV/HLS 三种协议格式的播放地址。本案例遇到的问题是,同一路直播流,使用H5播放器播放RTMP和HLS流正常,而播放FLV流则起播速度非常慢,超过2分钟才能播放出画面。

使用Flash播放器正常

由于RTMP和HLS是正常的,因此可以排除是GOP引起的起播慢。为了对比测试,用Flash去测试播放FLV流,发现速度非常快。这里推荐两个Flash播放器
(1)阿里云Web播放器Aliplayer
image.png
(2)第三方Flash播放器,示例HTML代码以及播放效果如下

<object>

<embed src="http://www.cutv.com/demo/live_test.swf" width="100%" height="100%"></embed>

</object>

image.png

使用FFplay播放器异常

为了增加可比性以及分析下直播流音视频格式,因此用FFMPEG的播放工具FFplay去播放测试,发现同样是播放FLV流速度很慢。播放RTMP原始流查看Meta信息发现该路直播流只有视频信息,无音频信息,具体结果如下图所示
image.png

直播实时监控分析

直播服务控制台提供了实时监控,参考阿里云官网帮助文档查看直播推流实时监控,可以看到直播流的音频头和视频头信息。其中AAC是音频头,AVC是视频头,如果推流端没有推音频和音频头,那么这里的AAC监控项数据就会是0,本案例就是这种情况。
image.png
image.png

结论和解决方案

通过以上测试结果和相关排查可以确认该问题跟不同播放器解码特性有关,结合相关资料进一步分析确认,大部分播放器器默认会等FLV流的音频,本案例中由于FLV流没有音频,导致播放器一直在"傻等",因此起播非常慢。

目前阿里云直播支持纯音频和纯视频直播,可以通过在播放URL后加onlyvideo=1参数来实现纯视频直播,加onlyaudio=1参数来实现纯音频直播。增加onlyvideo=1以后,阿里云直播服务在FLV封装格式中会明确声明没有音频,可以避免播放"傻等"。

目录
相关文章
|
2月前
|
算法 数据可视化
bilibili视频流量数据潜望镜
bilibili视频流量数据潜望镜
|
12月前
|
存储 编解码 缓存
海康摄像头开发笔记(一):连接防爆摄像头、配置摄像头网段、设置rtsp码流、播放rtsp流、获取rtsp流、调优rtsp流播放延迟以及录像存储
Hik防爆摄像头录像,因为防爆摄像头会有对应的APP软件,与普通的网络摄像头和球机不一样,默认认为它不可以通过web网页配置,所以弄了个来实测确认。经测试实际上也是可以通过web网页配置(与网络摄像头基本是一致的,在码流方面可能会有些不一样),然后提取rtsp流的,界面与球机无异,只是没有球机的云台控制功能,但是界面上也是有的。
海康摄像头开发笔记(一):连接防爆摄像头、配置摄像头网段、设置rtsp码流、播放rtsp流、获取rtsp流、调优rtsp流播放延迟以及录像存储
|
11月前
|
网络协议
rtmp改udp推流,并测试延时性能
rtmp改udp推流,并测试延时性能
216 0
rtmp改udp推流,并测试延时性能
|
11月前
|
编解码 测试技术
srt推拉流延时性能测试
srt推拉流延时性能测试
274 0
srt推拉流延时性能测试
|
12月前
|
容器
flv拉流在项目中如何使用(二)
这里主要是我们不能使用video容器自带的暂停和播放按钮了,我们要隐藏原来的自己实现暂停和播放。暂停和播放说白了就是断流和重新拉流
115 1
|
10月前
|
编解码 开发工具 图形学
Unity环境下RTMP推流+RTMP播放低延迟解决方案
在本文之前,我们发布了Unity环境下的RTMP推流(Windows平台+Android平台)和RTMP|RTSP拉流(Windows平台+Android平台+iOS平台)低延迟的解决方案,今天做个整体汇总,权当抛砖引玉。
479 0
|
11月前
|
编解码 监控 网络协议
什么是视频推流和视频拉流?视频推流和视频拉流都涉及哪些技术?一文带您了解!
什么是视频推流和视频拉流?视频推流和视频拉流都涉及哪些技术?一文带您了解!
3268 0
|
12月前
|
移动开发 前端开发 网络协议
flv拉流在项目中如何使用(一)
最近做的项目里面用到通过前端flv.js拉流播放直播视频(实时视频);这里给大家介绍一下流程,首先是前端发送请求后端给返回一个直播流指定地址,然后前端把这个地址通过flv处理放到video容器中进行播放;
338 0
|
12月前
|
Web App开发 编解码 网络协议
网页端WebRTC推流转换为RTMP/GB28181等其他直播流协议
网页端WebRTC推流转换为RTMP/GB28181等其他直播流协议
257 0
|
12月前
|
编解码 网络协议 内存技术
实现输出h264直播流的rtmp服务器 flash直播服务器
实现输出h264直播流的rtmp服务器 flash直播服务器
154 0