微信小程序解除10个请求并发限制


Posted in Javascript onDecember 18, 2018

这可能是一个冷消息,所以标题比较劲爆。

小程序并发限制由来已久,从刚发布时的 5 并发,到后来的 10 并发,同时发出的请求数若超出这个限制则将被残忍抛弃,由此催生了很多开发者在自己的项目中造了「请求排队」的轮子。然而事实上,早在一年半以前,该限制就被微信官方取消。

10 个请求的并发限制

关于并发限制,微信开发者文档中是这么写的:

微信小程序解除10个请求并发限制

这一限制的意思是在同一时刻, wx.requestwx.uploadFilewx.downloadFile 加起来的并发总数不能超出 10 个。

至今,仍有很多开发者一直遵守着这个规则。

许多人在写业务的时候小心翼翼地维护着请求数。为了将请求数控制好,特地将一些并行请求改为串行,或者引入请求队列来维护小程序请求。

这部分资深开发者为了遵守这一规则所花的功夫,多少反映出了早年他们在面对数额超出后请求被残忍抛弃时的无奈。

附小程序基础库版本 1.3.0 的控制台报错:

微信小程序解除10个请求并发限制

时至今日,仍有开发者在讨论解决小程序并发限制的方法:

微信小程序解除10个请求并发限制

被忽略的消息

实际上,微信在 2017 年 7 月的基础库 1.4.0 版本升级中就做了优化,对超过并发限制的请求做了队列处理,只是还有很多开发者并不知道这一消息。

从严格意义上来说,此次优化并没有完全解除原有的并发限制。目前同时处理请求的上限仍是 10 个,但在 10 个以外的请求会排队,当前面有请求完成的时候,队列中的请求按顺序发送并处理,*不会像之前那样直接将超出 10 个的请求丢弃

附件小程序基础库 1.4.0 更新日志(部分):

微信小程序解除10个请求并发限制

现在,我们终于可以忽略请求并发限制,愉快地发送请求了。毕竟请求都是可以都发送出去的,只不过在效率上会比无并发限制的情况慢一些。

发送请求的正确姿势

如上文所说,微信小程序是在基础库 1.4.0 版本中加入对超过并发限制的请求做队列处理优化的,在 1.4.0 以下的版本中超出并发部分的请求会被丢弃。

据微信官方数据,截止到 2018 年 12 月,1.4.0 版本以下用户占比大约是 0.04%,虽然目前小程序很少会兼容到这么低的版本,但是对一些有特殊需要的小程序也要注意基础库的差异。

另外要注意的是小程序并发请求的排队机制。当同时调用的请求超过 10 个时,小程序会先发起 10 个并发请求,超过 10 个的部分按调用顺序进行排队,当前一个请求完成时,再发送队列中的下一个请求。

附 20 个请求并发测试:

微信小程序解除10个请求并发限制

测试结果:

微信小程序解除10个请求并发限制

从图中可以看到,前 10 个请求同时发出,而后面的请求的起始点,对应了前面某个请求的结束点,可以反映出请求的排队行为。

这意味着,在并发请求很多的时候应该做好排队策略,按请求的重要程度和响应时间调整调用顺序,如果遇到请求的响应很慢的情况,可以考虑做 timeout 处理,以免大量等待,影响用户体验。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
javascript中的事件代理初探
Mar 08 Javascript
JavaScript面向对象的实现方法小结
Apr 14 Javascript
微信小程序  audio音频播放详解及实例
Nov 02 Javascript
EasyUI折叠表格层次显示detailview详解及实例
Dec 28 Javascript
vue.js中mint-ui框架的使用方法
May 12 Javascript
基于js中document.cookie全面解析
Sep 14 Javascript
Redux 和 Mobx的选择问题:让你不再困惑!
Sep 18 Javascript
JS控制GIF图片的停止与显示
Oct 24 Javascript
原生JS利用transform实现banner的无限滚动示例代码
Jun 15 Javascript
Vue开发中常见的套路和技巧总结
Nov 24 Vue.js
js面向对象方式实现拖拽效果
Mar 03 Javascript
JS实现简单的九宫格抽奖
Jun 28 Javascript
vue项目中axios请求网络接口封装的示例代码
Dec 18 #Javascript
vue中引入第三方字体文件的方法示例
Dec 17 #Javascript
vue 表单验证按钮事件交由父组件触发的方法
Dec 17 #Javascript
Vue 报错TypeError: this.$set is not a function 的解决方法
Dec 17 #Javascript
vuex 解决报错this.$store.commit is not a function的方法
Dec 17 #Javascript
详解Vue This$Store总结
Dec 17 #Javascript
vue + element-ui的分页问题实现
Dec 17 #Javascript
You might like
如何选购合适的收音机
2021/03/01 无线电
PHP 表单提交给自己
2008/07/24 PHP
PHP cURL初始化和执行方法入门级代码
2015/05/28 PHP
基于jsTree的无限级树JSON数据的转换代码
2010/07/27 Javascript
IE中jquery.form中ajax提交没反应解决方法分享
2012/09/11 Javascript
通过JQuery将DIV的滚动条滚动到指定的位置方便自动定位
2014/05/05 Javascript
javaScript中slice函数用法实例分析
2015/06/08 Javascript
jQuery的实例及必知重要的jQuery选择器详解
2016/05/20 Javascript
js改变透明度实现轮播图的算法
2020/08/24 Javascript
JavaScript之cookie技术详解
2016/11/18 Javascript
vue2.0开发实践总结之疑难篇
2016/12/07 Javascript
微信小程序实战之运维小项目
2017/01/17 Javascript
bootstrap table 数据表格行内修改的实现代码
2017/02/13 Javascript
js模拟支付宝密码输入框
2017/04/11 Javascript
详解Node.js access_token的获取、存储及更新
2017/06/20 Javascript
jQuery实现上传图片前预览效果功能
2017/08/03 jQuery
jQuery取得元素标签名称小结(附代码)
2017/08/16 jQuery
Promise.all中对于reject的处理方法
2018/08/01 Javascript
Bootstrap Table实现定时刷新数据的方法
2018/08/13 Javascript
node.js环境搭建图文详解
2018/09/19 Javascript
Javascript迭代、递推、穷举、递归常用算法实例讲解
2019/02/01 Javascript
利用Electron简单撸一个Markdown编辑器的方法
2019/06/10 Javascript
JavaScript封装单向链表的示例代码
2020/09/17 Javascript
Python标准库之随机数 (math包、random包)介绍
2014/11/25 Python
Python多线程编程(三):threading.Thread类的重要函数和方法
2015/04/05 Python
Python线程创建和终止实例代码
2018/01/20 Python
python实现超市扫码仪计费
2018/05/30 Python
python openssl模块安装及用法
2020/12/06 Python
怎样声明一个匿名的内部类
2016/06/01 面试题
机械专业应届生求职信
2013/09/21 职场文书
酒店总经理欢迎词
2014/01/08 职场文书
电子商务专业毕业生求职信
2014/06/12 职场文书
幼儿园社区活动总结
2014/07/07 职场文书
离婚协议书范本样本
2014/08/19 职场文书
学生无故旷课检讨书
2014/09/20 职场文书
Python编程源码报错解决方法总结经验分享
2021/10/05 Python