《直播疑难杂症排查系列》之一:播放失败

author author     2022-08-28     285

关键词:

直播疑难杂症排查 — 序


《直播疑难杂症排查系列》会涵盖的内容包括但不限于如下一些主题:

  • 播放失败

  • 直播卡顿

  • 首开慢

  • 延时高

  • 音画不同步

  • 马赛克严重

  • 播放黑屏、花屏、绿屏

  • 播放杂音、噪音、回声

  • 点播拖动不准

  • 直播发热问题

  • 其他问题(待续)

第一篇文章我们从播放开始,因为观看直播最重要的一个环节就是打开播放器,很多问题的直接反馈也是来自观众端。

导致播放失败的原因有很多种,不一定是播放器本身的问题,不过通过播放器,我们很容易反过来排查服务端或者推流端的问题。下面我们会从播放失败的表现、播放问题排查工具、常见问题分析等多个方面展开讨论。


播放失败的表现

播放失败的表现总结下来包括但不限于以下这些:

  1. 界面上一直显示「加载中」,或者提示播放失败的错误;

  2. 播放画面卡死不动,但 UI 按钮可以点击;

  3. 有声音没有画面,有画面没有声音。

这里并不讨论如播放卡顿、音画不同步、马赛克、延时、花屏等问题,这些话题,我们将会在后续的文章中探讨,本文重点关注的是:为啥无法顺利 「打开」 直播流 ?

播放问题的排查工具

一旦我们遇到视频播放不了,第一件事,就是要找几个别的播放器也播放看看,做一下对比测试,或者对码流做一些基础分析,以便更好地定位问题的源头,各个平台比较常见的播放/分析工具有如下几个:

常见播放失败问题排查

  • 基础概念

从给播放器传入播放地址,到播放画面显示出来,一般有如下几个步骤:

  1. DNS 解析,将播放地址中的域名解析为对应的服务器 IP 地址;

  2. 连接服务器,完成 http 请求或者 rtmp 握手过程;

  3. 接收服务器发送的数据,解协议解封装,拿到音视频数据解码播放。

任何一个环节出了问题,都有可能导致播放失败,不同的协议,由于协议层原因,播放报错往往不太一样,我们下面的讨论,主要以 RTMP/HTTP 这两种协议为主,假设正常的播放测试地址如下:
香港卫视的 RTMP 直播流:rtmp://live.hkstv.hk.lxdns.com/live/hks
W3C School 的测试 mp4 流:http://www.w3school.com.cn/i/movie.mp4

  • 域名解析失败

如果播放地址的域名无法解析,会导致播放失败,一般断网了或者域名无效,则播放的时候,会有类似如下报错:

$ffplay rtmp://live.hkstv.hk.lxdns.com1/live/hksFailed to resolve hostname live.hkstv.hk.lxdns.com1: nodename nor servname provided, or not known
Failed to resolve hostname live.hkstv.hk.lxdns.com1: No address associated with hostname

当然,如果有网络,但是域名解析失败,一般 ISP 运营商可能会返回一些类似 404 页面,或者跳转到其他的默认网页,因此,对于 HLS,HTTP-FLV,HTTP-mp4 等码流,会因为读到一些「脏数据」从而返回一些其他的错误,例如:

$ffplay rtmp://live.hkstv.hk.lxdns.com1/live/hksFailed to resolve hostname live.hkstv.hk.lxdns.com1: nodename nor servname provided, or not known
Failed to resolve hostname live.hkstv.hk.lxdns.com1: No address associated with hostname

遇到这类错误,一般可以通过 ping 一下域名试试,看看是否可以 ping 通,如果 ping 不通,则可能要检查下域名解析的配置了。

  • 服务器连接失败

如果域名正确,并且有网络连接的状态,多半是可以正常解析出服务器 ip 地址的,但是依然有连接失败的可能,比如,这台服务器相应的服务挂掉了,或者并没有在相应的端口提供服务,从而导致播放器连接失败,类似问题的报错如下:

$ ffplay rtmp://www.jhuster.com/live/hksCannot open connection tcp://www.jhuster.com:1935rtmp://www.jhuster.com/live/hks: Operation timed out

因为 www.jhuster.com 对应的服务器并没有提供 rtmp 拉流服务,因此通过 1935 连接该服务器会失败。

$ ffplay https://www.w3school.com.cn/i/movie.mp4Connection to tcp://www.w3school.com.cn:443 failed: Connection refused

因为 www.w3school.com.cn 并不支持 https 访问,因此通过 443 接口请求 https 连接失败。

当然,也有可能是这台服务器虽然提供了 rtmp 拉流服务但是宕机了,因此,我们需要通过 dig 命令确定最终访问的是哪一台服务器,并排查下该服务器为什么无法连接,当然,最好是修改下 ffpmeg 源码,把解析出来的服务器 IP 地址打印出来,这样就可以直接看到所连接的服务器地址了。

  • 请求的资源不存在

对于 http 协议的直播地址,请求的播放资源不存在,返回的错误还是比较快的,比如:

$ ffplay http://jhuster.com/live/hks.mp4http://jhuster.com/live/hks.mp4: Server returned 404 Not Found$ ffplay http://www.w3school2.com.cn/i/movie2.mp4http://www.w3school2.com.cn/i/movie2.mp4: Invalid data found when processing input

注:由于读到 ISP 运营商返回的跳转页面的 「脏数据」,因此也有可能返回上面这种错误。

而 RTMP 直播协议,跟 HTTP 协议的播放,有着一个很大的不同,就是播放器请求的数据,并不一定 「存放」在服务器,因此,服务器无法简单通过 URI 定位不到则返回 404,这些数据可能是在 RTMP 握手之后,由生产端逐步产生并由服务器转发到客户端,因此很难简单判断说 「资源不存在」。

通常 RTMP 协议的直播流,如果推流端没有推流了,播放器这边一般是读数据超时后才会返回错误,例如:

$ ffplay rtmp://live.hkstv.hk.lxdns.com/live/hks1rtmp://live.hkstv.hk.lxdns.com/live/hks1: Input/output error
  • 不支持的格式

视频流的采用的网络协议、编码格式、封装格式有很多种,网络协议比如 http/https/rtmp/rtsp 等等,编码格式比如 h.264,mpeg4,aac,speex 等等,封装格式比如 flv,mp4,avi,rmvb 等等,这些协议和格式的流,都是需要播放器专门添加支持的,因此,播放器遇到不支持的协议或者格式,也会导致播放失败,如下所示:

https://www.jhuster.com/xxxx.mp4 Protocol not foundhttps://www.jhuster.com/xxxx.rmvb Invalid data found when processing input

只有音频没有视频,或者只有视频没有音频

出现该错误的原因可能有如下几点:

  1. 音频/视频的编码格式不支持,导致解码失败

  2. 音频/视频的数据内容异常,导致解码失败

  3. 基于 ffmpeg 的播放器的 probesize 设置太小,导致解析码流信息不足

  4. 码流/文件本身的前半段只有音频没有视频,或者只有视频没有音频

这个问题播放启动流程已经完成,只是出现了画面缺失、或者音频缺失,也算是一种播放失败,限于本文篇幅,该问题后面会抽出专门的章节来分析。

  • 其他播放失败

上面只分析了常见的播放失败问题,其实导致播放失败的原因还有很多种,这里无法一一都列出来,不过通过 ffplay 的报错,就可能知道大概的原因,再联合服务端一起调试调试,一般都是可以找到根本原因的。下面是 ffmpeg 常见的错误分类:
http://ffmpeg.org/doxygen/trunk/error_8h_source.html

技术分享


本文作者:卢俊@七牛云。如果有你感兴趣的问题,但是不在上述列表中,也可以来信 [email protected] 交流,欢迎关注新浪微博 @卢_俊 或者 微信公众号 @Jhuster 获取最新的文章和资讯。

本文出自 “七牛云” 博客,转载请与作者联系!

如何解决直播过程中的直播功耗高问题|直播疑难杂症排查

...术详解》系列文章之后,我们推出了这个新的系列《直播疑难杂症排查》,把解决直播问题的经验逐步分享出来,同时也会穿插一些音视频开发的基础知识和优化经验,希望能够帮助到直播领域的开发者们。 本系列会涵盖的... 查看详情

直播疑难杂症排查—拖动不准

本文为《直播疑难杂症排查》系列的第九篇文章,我们重点看看播放视频时拖动不准的问题。1.问题现象播放过程中,拖动进度条后,实际播放的位置跟松开拖动时的位置相差很远。2.问题排查由于直播流是实时产生和传输的,... 查看详情

直播疑难杂症排查—播放卡顿

本文是《直播疑难杂症排查》系列的第二篇文章,我们主要分析下如何排查播放卡顿问题。1.播放卡顿的表现播放卡顿的表现总结下来包括但不限于以下这些:-频繁出现缓冲-播放不够流畅,画面一卡一卡的2.常见播放卡顿问题排... 查看详情

直播疑难杂症排查—首开慢

本文是《直播疑难杂症排查》系列的第三篇文章,我们来看看直播过程中,最重要的一个性能指标:首开。1.首开慢的表现点击播放后,需要好几秒才能显示播放画面。2.常见首开慢问题排查2.1点击播放后才从服务器取播放地址... 查看详情

直播疑难杂症排查—播放杂音噪音回声问题

本文为《直播疑难杂症排查》系列的第八篇文章,我们重点看看直播过程中出现的杂音、噪音和回声等问题。相比于视频而言,音频要敏感得多,视频画面有噪点、马赛克都还是可以勉强被接受,而声音一旦有任何瑕疵,人耳都... 查看详情

直播疑难杂症排查—延时高

本文是《直播疑难杂症排查》系列的第四篇文章,我们来看看直播的延时问题。1.延时的测量一般测量延时最简单的方法,就是推流端和播放端对着同一个时钟,然后用播放端显示的时间减去推流端显示的时间,就得到了粗略的... 查看详情

直播疑难杂症排查—黑屏花屏闪屏问题

本文是《直播疑难杂症排查》系列的第七篇文章,我们来重点看看直播中常见的各种黑屏、花屏、闪屏问题。首先我们要明白,黑屏、花屏、闪屏等问题,可能是推流端的问题,也可能是播放器的问题,遇到这些现象,我们要第... 查看详情

直播疑难杂症排查—音画不同步

本文是《直播疑难杂症排查》系列的第五篇文章,我们重点来看看直播中常见的音画不同步问题。1.音画不同步的表现很容易判断,就是画面和声音不匹配。2.音画同步的基础概念首先我们要明白一个概念,虽然人的肉眼,很容... 查看详情

系列序—直播疑难杂症排查

在七牛做直播SDK一年多了,帮助客户解决过各种形形色色的问题,如直播卡顿、马赛克、花屏、黑屏、杂音、音画不同步等等等等,这其中,有一些是网络原因,有一些是客户的使用姿势问题,有一些是参数配置错误,当然,也... 查看详情

直播疑难杂症排查(10)—直播功耗高

本文为《直播疑难杂症排查系列的》第十篇文章,我们重点看看直播功耗高的问题。1. 问题现象直播过程中手机发热严重,耗电快。2.问题排查导致手机功耗高,发热严重的根本因素,无外乎就是一点:CPU/GPU占用率高,所以... 查看详情

直播疑难杂症排查—序

在七牛做直播SDK一年多了,帮助客户解决过各种形形色色的问题,如直播卡顿、马赛克、花屏、黑屏、杂音、音画不同步等等等等,这其中,有一些是网络原因,有一些是客户的使用姿势问题,有一些是参数配置错误,当然,也... 查看详情

直播疑难杂症排查—马赛克严重

本文是《直播疑难杂症排查》系列的第六篇文章,我们重点来看看直播中常见的马赛克问题。1.马赛克问题的表现马赛克主要是指画面中出现多处类似小方块的图像,导致画面的局部或者整体看不清楚的情况。650)this.width=650;"src="... 查看详情

easynvr视频通道录像计划的录像文件播放失败问题排查

TSINGSEE青犀视频云-边-端架构视频智能分析平台EasyNVR分为直播版和录像版。直播版内没有视频存储以及视频录像检索、回看的功能,而录像版则具备直播+存储+录像回看功能,两者大家可以自由选择。在我们对EasyNVR... 查看详情

大数据问题排查系列-大数据集群开启kerberos认证后hive作业执行失败(代码片段)

大数据问题排查系列-大数据集群开启kerberos认证后HIVE作业执行失败1前言大家好,我是明哥!本文是大数据问题排查系列的kerberos问题排查子序列博文之一,讲述大数据集群开启kerberos安全认证后,hive作业执行失败... 查看详情

avs系统7.0版本疑难杂症修复系列之一(undefinedvariable:dir_handleinfunction_thumbs.phponline44)

AVS系统7.0版本,网上找的免费版本,有很多问题,本着研究代码提升水平的精神,遇到什么问题就寻找解决办法。今天遇到的问题是,打开管理后台进入视频管理页面,报了一个错误:Notice: Undefinedvari... 查看详情

easynvr视频广场按需播放hls直播流总是断流原因排查(代码片段)

EasyNVR视频监控综合管理平台支持多种格式视频流的直播播放,包括HLS、FLV、RTSP等,今年我们在此基础上又开发了WebRTC格式的播放,并且将该格式拓展到其他平台,比如EasyGBS。如果大家有兴趣可以直接下载测试。... 查看详情

easynvr视频点击开始录像提示“创建录像文件失败”排查

...说十分省心。在项目使用上,有用户会遇到EasyNVR播放直播视频流点击开始录像,提示创建录像文件失败的情况,界面显示如下:查找代码发现录像是保存在项目下的downloads目录下的一个mp4文件,而代码里创建... 查看详情

wpf疑难杂症之一(3d场景)

原文:WPF疑难杂症之一(3D场景)最近2个月一直在学习WPF,在实际的开发中遇到下面一个3D场景有关的问题,我先给出问题代码:首先是在资源中定义了一个3D变换组:<Windowx:Class="Viewer3D.MainWindow"   xmlns="http://schemas.mic... 查看详情