微信小程序解除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的blockui插件显示弹出层
Apr 14 Javascript
JavaScript省市联动实现代码
Feb 15 Javascript
jQuery性能优化的38个建议
Mar 04 Javascript
jQuery实现的感应鼠标悬停图片色彩渐显效果
Mar 03 Javascript
javascript Array 数组常用方法
Apr 05 Javascript
深入浅析JavaScript的API设计原则
Jun 14 Javascript
Angular2内置指令NgFor和NgIf详解
Aug 03 Javascript
JS实现的幻灯片切换显示效果
Sep 07 Javascript
详解MVC如何使用开源分页插件(shenniu.pager.js)
Dec 16 Javascript
Vue作用域插槽slot-scope实例代码
Sep 05 Javascript
js实现倒计时器自定义时间和暂停
Feb 25 Javascript
vue移动端的左右滑动事件详解
Jun 17 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
实战mysql导出中文乱码及phpmyadmin导入中文乱码的解决方法
2010/06/11 PHP
PHP+sqlite数据库操作示例(创建/打开/插入/检索)
2016/05/26 PHP
PHP简单获取多个checkbox值的方法
2016/06/13 PHP
浅谈PHP中的面向对象OOP中的魔术方法
2017/06/12 PHP
jQuery弹出层插件简化版代码下载
2008/10/16 Javascript
jquery实现的带缩略图的焦点图片切换(自动播放/响应鼠标动作)
2013/01/23 Javascript
js类型转换与引用类型详解(Boolean_Number_String)
2014/03/07 Javascript
nodeJs爬虫获取数据简单实现代码
2016/03/29 NodeJs
JavaScript数组和对象的复制
2017/03/21 Javascript
在JS中如何把毫秒转换成规定的日期时间格式实例
2017/05/11 Javascript
微信小程序本地缓存数据增删改查实例详解
2017/05/24 Javascript
Angular弹出模态框的两种方式
2017/10/19 Javascript
Vue2.0+ElementUI实现表格翻页的实例
2017/10/23 Javascript
vue项目如何刷新当前页面的方法
2018/05/18 Javascript
解决Vue打包后访问图片/图标不显示的问题
2019/07/25 Javascript
Vue通过配置WebSocket并实现群聊功能
2019/12/31 Javascript
JavaScript实现PC端四格密码输入框功能
2020/02/19 Javascript
Vue实现附件上传功能
2020/05/28 Javascript
国内常用的js类库大全(CDN公共库)
2020/06/24 Javascript
完美解决Python2操作中文名文件乱码的问题
2017/01/04 Python
Python批处理更改文件名os.rename的方法
2018/10/26 Python
python中ImageTk.PhotoImage()不显示图片却不报错问题解决
2018/12/06 Python
OpenCV模板匹配matchTemplate的实现
2019/10/18 Python
使用python实现画AR模型时序图
2019/11/20 Python
Python如何实现小程序 无限求和平均
2020/02/18 Python
Python标准库:内置函数max(iterable, *[, key, default])说明
2020/04/25 Python
详解python如何引用包package
2020/06/07 Python
Python实现爬取网页中动态加载的数据
2020/08/17 Python
python 窃取摄像头照片的实现示例
2021/01/08 Python
澳大利亚领先的在线机械五金、园艺和存储专家:Edisons
2018/03/24 全球购物
Topshop美国官网:英国快速时尚品牌
2019/05/16 全球购物
英国卫浴商店:Ergonomic Design
2019/09/22 全球购物
施工员岗位职责
2014/03/16 职场文书
治超工作实施方案
2014/05/04 职场文书
水污染治理工程专业求职信
2014/06/14 职场文书
国情备忘录观后感
2015/06/04 职场文书