标签:播放器 定时器 浏览器 播放 Chrome flv EasyPlayer
EasyPlayer播放器系列项目是TSINGSEE青犀视频开发的极具开放性的播放器项目,用户可以根据自己的需求调用接口或者进行开发,实用性强,稳定性也非常优越,很多用户调用EasyPlayer播放器自行做开发或者集成。
在最近在使用@easydarwin/easyplayer播放器过程中播放多路flv流出现的浏览器崩溃问题。经过分析源码发现程序内有个定时器:
this.player.on("ended", () => {
if (this.live) {
this.isWaiting = true;
this.timers = setInterval(this.myTimer, 1000);
}
});
在播放flv出现断流时,播放触发了定时器,定时器里面实现了播放器的创建和销毁。由于这一步操作短时间创建大量flv流请求,但是播放器并不知道flv流什么时候恢复正常,无法及时销毁这个定时任务。Chrome浏览器最多允许对同一个域名Host建立6个TCP连接,不同的浏览器有所区别,所以才导致浏览器出现崩溃。
如果想实现flv断流重连,可使用最新的easyplayer和保活通道接口配合来初始化播放器和销毁播放器。参考代码如下:
<EasyPlayer
ref="easyPlayer"
live
:aspect="aspect"
:onDemand="true"
:autoplay="autoplay"
v-loading="bLoading"
:loading.sync="bLoading"
:videoUrl="oldVideoUrl"
element-loading-text="加载中..."
element-loading-background="#000"
@message="$message"
fluent
stretch
@ended="onPlayEnded"
/>
this.$refs.easyPlayer.initVideoJS();
this.$refs.easyPlayer.destroyVideoJS()
标签:播放器,定时器,浏览器,播放,Chrome,flv,EasyPlayer 来源: https://www.cnblogs.com/TSINGSEE/p/15562562.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。