今天遇到了一個(gè)在IjkPlayer播放中途切換拉流協(xié)議播放失敗的問題。
http-flv協(xié)議的拉流地址切換到rtmp協(xié)議的拉流地址,播放失敗,并報(bào)-10000的錯(cuò)誤。
而銷毀再重建播放器,則可以播放成功。
上ijkplayer的issue上面查了同樣的幾個(gè)問題,發(fā)現(xiàn)開啟如下的選項(xiàng)可以解決問題:
ijkPlayer.setOption(IjkMediaPlayer.OPT_CATEGORY_FORMAT, "dns_cache_clear", 1);
大致原因是:
rtmp的url為:
rtmp://abc
http-flv的url為:
https:abc.flv
這兩個(gè)url指向了相同的ip地址,但是不同的端口號(hào),https的端口號(hào)是443,rtmp的端口號(hào)是1935。而Ijkplayer應(yīng)該是對(duì)請(qǐng)求的緩存策略有bug,只用了ip地址作為緩存池的key,正確的做法應(yīng)該是(ip地址+端口號(hào))。
有人已經(jīng)改了c層的代碼,用ip+port作為key,來解決了緩存的bug。https://patchwork.ffmpeg.org/patch/10543/mbox/
而我用的另一種解決方式就是取消掉緩存,就可以解決這個(gè)問題。
參考:
cannot play hls after playing rtsp stream