我正在观察 AVPlayer 的 KVO AVPlayerItemNewErrorLogEntryNotification,发现以下错误:
errorStatusCode:-12645 errorDomain :CoreMediaErrorDomain errorComment:Internal error: restart too far ahead (-1.4084s)
我无法理解以下行的真正含义。
“内部错误:重启太早了”
谁能帮我找到这个问题的根本原因。
我正在观察 AVPlayer 的 KVO AVPlayerItemNewErrorLogEntryNotification,发现以下错误:
errorStatusCode:-12645 errorDomain :CoreMediaErrorDomain errorComment:Internal error: restart too far ahead (-1.4084s)
我无法理解以下行的真正含义。
“内部错误:重启太早了”
谁能帮我找到这个问题的根本原因。
如果长 .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 -
根据 Apple 员工的说法,此错误消息意味着:
播放器抱怨它试图重新开始直播,但只有 1.4 秒的可用素材。您的直播播放列表中有多少片段?这些天来,我们建议您始终在播放列表中至少有六个片段。我相信唯一的效果是延迟回拨,直到它有足够的数据。
来源:https ://forums.developer.apple.com/thread/40791
当流式传输直播节目(例如任何电视频道)时,在事件数据的可用性与创建媒体片段 (.ts) 的编码器之间存在延迟,然后将其附加到播放列表。
我可以想象如果 playerItem 播放头的位置位于缓冲区的最边缘并且新媒体段在服务器上的可用速度不够快,则会生成这些类型的错误。
由于这些错误被报告为internal
并且 AVPlayer 显然从中恢复,因此可以安全地假设它们正在内部处理。因此,它们可以被理解为简单的错误报告,并且可以选择忽略它们。
如果想要阻止它们,唯一的方法可能是手动将实时缓冲区的边缘及时设置回几秒钟。