微信小程序解除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 相关文章推荐
JQUERY dialog的用法详细解析
Dec 19 Javascript
采用call方式实现js继承
May 20 Javascript
jquery.map()方法的使用详解
Jul 09 Javascript
js限制文本框只能输入中文的方法
Aug 11 Javascript
基于BootStrap实现局部刷新分页实例代码
Aug 08 Javascript
学习掌握JavaScript中this的使用技巧
Aug 29 Javascript
jQuery基于排序功能实现上移、下移的方法
Nov 26 Javascript
JavaScript获取服务器时间的方法详解
Dec 11 Javascript
详解webpack+vue-cli项目打包技巧
Jun 17 Javascript
vue+element实现表单校验功能
May 20 Javascript
如何在项目中使用log4.js的方法步骤
Jul 16 Javascript
ng-alain的sf如何自定义部件的流程
Jun 12 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
用Zend Encode编写开发PHP程序
2006/10/09 PHP
详解php中反射的应用
2016/03/15 PHP
PHP用户验证和标签推荐的简单使用
2016/10/31 PHP
php使用str_replace替换多维数组的实现方法分析
2017/06/15 PHP
laravel解决迁移文件一次删除创建字段报错的问题
2019/10/24 PHP
js控制div及网页相关属性的代码
2009/12/19 Javascript
Prototype源码浅析 Enumerable部分(二)
2012/01/18 Javascript
jQuery中show与hide方法用法示例
2016/09/16 Javascript
AngularJS ng-template寄宿方式用法分析
2016/11/07 Javascript
详解vue之页面缓存问题(基于2.0)
2017/01/10 Javascript
vue之数据交互实例代码
2017/06/20 Javascript
JavaScript正则表达式校验与递归函数实际应用实例解析
2017/08/04 Javascript
js移动端事件基础及常用事件库详解
2017/08/15 Javascript
详解vue axios二次封装
2018/07/22 Javascript
基于Node.js的大文件分片上传示例
2019/06/19 Javascript
node删除、复制文件或文件夹示例代码
2019/08/13 Javascript
JS实现可用滑块滑动的缓动图代码
2019/09/01 Javascript
vue中使用百度脑图kityminder-core二次开发的实现
2019/09/26 Javascript
JavaScript中的惰性载入函数及优势
2020/02/18 Javascript
如何在vue-cli中使用css-loader实现css module
2021/01/07 Vue.js
python获取本机mac地址和ip地址的方法
2015/04/29 Python
Python爬虫DOTA排行榜爬取实例(分享)
2017/06/13 Python
Python使用 Beanstalkd 做异步任务处理的方法
2018/04/24 Python
替换python字典中的key值方法
2018/07/06 Python
使用python进行波形及频谱绘制的方法
2019/06/17 Python
Python实现12306火车票抢票系统
2019/07/04 Python
Python 使用list和tuple+条件判断详解
2019/07/30 Python
扩展Django admin的list_filter()可使用范围方法
2019/08/21 Python
python 实现单通道转3通道
2019/12/03 Python
英语系毕业生求职信
2014/07/13 职场文书
公司离职证明范本
2014/10/17 职场文书
简易离婚协议书范本
2014/10/24 职场文书
网络管理员岗位职责
2015/02/12 职场文书
年中了,该如何写好个人述职报告?
2019/07/02 职场文书
python中Matplotlib绘制直线的实例代码
2021/07/04 Python
Python中npy和mat文件的保存与读取
2022/04/24 Python