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

界面上一直显示「加载中」,或者提示播放失败的错误;
播放画面卡死不动,但 UI 按钮可以点击;
有声音没有画面,有画面没有声音。
这里并不讨论如播放卡顿、音画不同步、马赛克、延时、花屏等问题,这些话题,我们将会在后续的文章中探讨,本文重点关注的是:为啥无法顺利 「打开」 直播流 ?

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

命令行工具:ffplay、ffprobe、mediainfo、hls-analyzer 等
网页端工具
http://www.cutv.com/demo/live_test.swf
http://www.ossrs.net/players/srs_player.html
App 应用:VLC,VPlayer,MXPlayer 等
Windows 工具:mp4info、FlvParse、FLVMeta、Elecard StreamEye Studio 等
常见播放失败问题排查
基础概念
从给播放器传入播放地址,到播放画面显示出来,一般有如下几个步骤:

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

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

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

任何一个环节出了问题,都有可能导致播放失败,不同的协议,由于协议层原因,播放报错往往不太一样,我们下面的讨论,主要以 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/hks
Failed 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/hks
Failed 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/hks
Cannot open connection tcp://www.jhuster.com:1935
rtmp://www.jhuster.com/live/hks: Operation timed out

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

$ ffplay https://www.w3school.com.cn/i/movie.mp4
Connection 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.mp4
http://jhuster.com/live/hks.mp4: Server returned 404 Not Found
$ ffplay http://www.w3school2.com.cn/i/movie2.mp4
http://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/hks1
rtmp://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 found
https://www.jhuster.com/xxxx.rmvb Invalid data found when processing input

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

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

音频/视频的编码格式不支持,导致解码失败
音频/视频的数据内容异常,导致解码失败
基于 ffmpeg 的播放器的 probesize 设置太小,导致解析码流信息不足
码流/文件本身的前半段只有音频没有视频,或者只有视频没有音频
这个问题播放启动流程已经完成,只是出现了画面缺失、或者音频缺失,也算是一种播放失败,限于本文篇幅,该问题后面会抽出专门的章节来分析。

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

直播APP开发公司、直播源码出售《直播疑难杂症排查系列》之 :播放失败相关推荐

  1. 直播app开发公司来教你从零开始实现在线直播

    直播app开发公司来教你从零开始实现在线直播 送走了共享经济,迎来了直播浪潮.作为一个开发者,总想去探索自己的未知领域.我今天将手把手教你搭建一个SRS直播流服务和一个Node.js服务.Node.j ...

  2. 直播app开发公司来告诉你什么是视频云

    直播app开发公司来告诉你什么是视频云 视频云服务是一种基于云计算技术理念的视频流媒体服务,它能够让客户以低成本.高效率的方式搭建专业的视频系统,从而轻松开展在线视频业务.在典型的视频云服务流程中,内 ...

  3. 直播app开发公司手把手搭建一套简单的直播系统

    一.目前直播产品的种类 泛娱乐化直播 - 花椒.映客等娱乐主播,还有斗鱼等游戏直播 实时互动直播 - 音视频会议.教育直播等,像钉钉,腾讯会议 1.目前泛娱乐化直播架构 2.实时互动直播架构 直播ap ...

  4. 基于电商直播SDK快速实现一个淘宝直播APP【内附源码】

    现在各大互联网APP都标配电商直播带货了,没有直播带货开发经验都感觉自己跟不上技术的进步.今天快速基于Java实现一个安卓端电商直播APP,深入理解整个电商直播开发流程.我们最终实现效果如下: 按照惯 ...

  5. APICloud AVM多端开发 | 《外卖app开发》项目源码深度解析(上)

    为了让开发者更加快速的学习和了解APICloud多端开发技术,APICloud平台特别推出一款多端源码-<餐饮点餐>,可以体验一套代码编译Android和iOS app+小程序. AVM多 ...

  6. 导游APP开发模板现源码

    导游APP开发,导游APP开发模板,导游APP开发现源码.每到节假日日的到来,大家都是会设计方案好相对应的出游计划,而旅行好像也成为了节假日的限度谜面.要想出门旅行除开要设计方案自身的出游计划以外,针 ...

  7. APICloud AVM多端开发 |《生鲜电商app开发》项目源码深度解析

    此项目为生鲜电商app开发类应用,主要功能包括商品列表.商品详情展示.购物车.登录注册.个人中心等. 项目源码在 https://github.com/apicloudcom/avm-simple 仓 ...

  8. 无人货架APP开发(软件源码)

    ​无人货架APP开发,无人货架APP开发源码.据调查,伴随着科学合理专业技能的进行及其用户需求的加上,无人货架APP应用的出现给线下推广实体线零售店产生了新的期待.从无人商场到无人连锁便利店再到无人零 ...

  9. 毕设课设基于Android的校园订餐APP开发(附源码)

    1.演示视频链接: https://www.bilibili.com/video/BV1N3411c7Pf/?vd_source=48f4d2985ad54326394e2e5947d91c22 2. ...

最新文章

  1. UI设计培训分享:app图标设计要遵循哪些原则
  2. 用 openSSL 生成 公钥 私钥
  3. Java后台获取前端传递的日期解析不了
  4. 华为rh5885服务器oid_华为RH5885H v3机架服务器RAID配置实例
  5. angular4更改表单中显示的值_angular4 Form表单相关
  6. DIV CSS初学者需重视的10个简单问题与技巧
  7. Python绘制sigmoid函数及其导数图像
  8. iptables命令详解
  9. [转载] Python语言程序设计基础(第二版)嵩天等课后习题答案
  10. 基于springboot的美食系统
  11. 32/64位Win7_2017.09通用多合一安装版/Ghost版
  12. android三国2,三国演义2单机版安卓
  13. ppt入门到精通全套视频教程,Word+Excel+PPT三合一教程(15G)
  14. RecyclerView添加分割线
  15. ARP协议格式和实例分析
  16. prop与自定义事件
  17. Spring Boot(一):概述(5)——Spring Boot项目推荐工程结构
  18. 区块链——智能合约入门知识
  19. as打开时出现The environment variable JAVA_HOME (with The value of C:\Java\jdk1.8.0_101\bin) does not poin
  20. 洛谷P4568 [JLOI2011] 飞行路线 题解

热门文章

  1. 什么是CSRF(跨站请求伪造)?
  2. CI520与CV520的兼容模式研发资料
  3. 基于Simulink的带通BPSK信号调制解调实验报告(含代码和slx文件)
  4. python语言编写的modbus协议_基于Python的ModbusTCP客户端实现
  5. android dex 加固,Dex文件加固
  6. 姓名学中五格的算法与吉凶
  7. 支持备份/还原win10系统的分区工具DiskGenius v4.9.3专业版下载+序列号注册文件激活教程
  8. 移植u-boot-2012-10到tiny210v2(一)-----基本芯片介绍和启动流程介绍
  9. Android开发RecyclerView刷新后item里面控件动画
  10. PHP商城二手交易市场课程设计