7

我正在观察 AVPlayer 的 KVO AVPlayerItemNewErrorLogEntryNotification,发现以下错误:

  • errorStatusCode:-12645 errorDomain :CoreMediaErrorDomain errorComment:Internal error: restart too far ahead (-1.4084s)

我无法理解以下行的真正含义。

“内部错误:重启太早了”

谁能帮我找到这个问题的根本原因。

4

2 回答 2

10

如果长 .ts 视频文件响应:-12645。

没有关于 MPMediaPlayer 在 MPMovieErrorLogEvent 类中返回的错误状态代码的文档。但其中一些是:

HTTP status - errorStatusCode - errorDomain - errorComment

400     -12666  CoreMediaErrorDomain    unrecognized http response 400  
401     -12937  CoreMediaErrorDomain    Authentication Error    
402     -12666  CoreMediaErrorDomain    unrecognized http response 402  
403     -12660  CoreMediaErrorDomain    HTTP 403: Forbidden     
404     -12938  CoreMediaErrorDomain    HTTP 404: File not found    
405     -12666  CoreMediaErrorDomain    unrecognized http response 405  
406     -12666  CoreMediaErrorDomain    unrecognized http response 406  
407     -12937  CoreMediaErrorDomain    Authentication Error    
409     -12666  CoreMediaErrorDomain    unrecognized http response 409  
...                 
415     -12666  CoreMediaErrorDomain    unrecognized http response 415  

500     -12666  CoreMediaErrorDomain    unrecognized http response 500  
501     -12666  CoreMediaErrorDomain    unrecognized http response 501  
502     -12666  CoreMediaErrorDomain    unrecognized http response 502  
503     -12661  CoreMediaErrorDomain    HTTP 503: Unavailable   
504     -12666  CoreMediaErrorDomain    unrecognized http response 504  
505     -12666  CoreMediaErrorDomain    unrecognized http response 505  

if long .ts video file respons  -12645  CoreMediaErrorDomain    No response for media file in 10 s  

video .ts file bitrate differ from m3u8 declaration     -12318  CoreMediaErrorDomain    Segment exceeds specified bandwidth for variant     

for live stream.playlist m3u8 did not change too long   -12642  CoreMediaErrorDomain    Playlist File unchanged for 2 consecutive reads     

if wrong host ip    -1004   kCFErrorDomainCFNetwork     -   

if wrong dns host name  -1003   kCFErrorDomainCFNetwork     -   

if bad formatted URL    -1000   kCFErrorDomainCFNetwork     -   

if invalid https/ssl request    -1202   kCFErrorDomainCFNetwork     -
于 2016-03-17T20:34:47.627 回答
5

根据 Apple 员工的说法,此错误消息意味着:

播放器抱怨它试图重新开始直播,但只有 1.4 秒的可用素材。您的直播播放列表中有多少片段?这些天来,我们建议您始终在播放列表中至少有六个片段。我相信唯一的效果是延迟回拨,直到它有足够的数据。

来源:https ://forums.developer.apple.com/thread/40791


错误的原因很可能源于 m3u8 本身。

当流式传输直播节目(例如任何电视频道)时,在事件数据的可用性与创建媒体片段 (.ts) 的编码器之间存在延迟,然后将其附加到播放列表。

我可以想象如果 playerItem 播放头的位置位于缓冲区的最边缘并且新媒体段在服务器上的可用速度不够快,则会生成这些类型的错误。


是否应在客户端防止或处理这些错误:

由于这些错误被报告为internal并且 AVPlayer 显然从中恢复,因此可以安全地假设它们正在内部处理。因此,它们可以被理解为简单的错误报告,并且可以选择忽略它们。

如果想要阻止它们,唯一的方法可能是手动将实时缓冲区的边缘及时设置回几秒钟。

于 2016-06-03T09:15:22.533 回答