这多是一个冷消息,因此标题比较劲爆。
小程序
小程序并发限制由来已久,从刚发布时的 5 并发,到后来的 10 并发,同时发出的请求数若超出这个限制则将被残忍抛弃,由此催生了不少开发者在本身的项目中造了「请求排队」的轮子。然而事实上,早在一年半之前,该限制就被微信官方取消。微信小程序
关于并发限制,微信开发者文档中是这么写的:微信
这一限制的意思是在同一时刻, wx.request
、wx.uploadFile
、wx.downloadFile
加起来的并发总数不能超出 10 个。微信开发
至今,仍有不少开发者一直遵照着这个规则。并发
许多人在写业务的时候当心翼翼地维护着请求数。为了将请求数控制好,特意将一些并行请求改成串行,或者引入请求队列来维护小程序请求。测试
这部分资深开发者为了遵照这一规则所花的功夫,多少反映出了早年他们在面对数额超出后请求被残忍抛弃时的无奈。优化
附小程序基础库版本 1.3.0 的控制台报错:spa
时至今日,仍有开发者在讨论解决小程序并发限制的方法:日志
实际上,微信在 2017 年 7 月的基础库 1.4.0 版本升级中就作了优化,对超过并发限制的请求作了队列处理,只是还有不少开发者并不知道这一消息。code
从严格意义上来讲,这次优化并无彻底解除原有的并发限制。目前同时处理请求的上限还是 10 个,但在 10 个之外的请求会排队,当前面有请求完成的时候,队列中的请求按顺序发送并处理,*不会像以前那样直接将超出 10 个的请求丢弃。
附件小程序基础库 1.4.0 更新日志(部分):
如今,咱们终于能够忽略请求并发限制,愉快地发送请求了。毕竟请求都是能够都发送出去的,只不过在效率上会比无并发限制的状况慢一些。
如上文所说,微信小程序是在基础库 1.4.0 版本中加入对超过并发限制的请求作队列处理优化的,在 1.4.0 如下的版本中超出并发部分的请求会被丢弃。
据微信官方数据,截止到 2018 年 12 月,1.4.0 版本如下用户占比大约是 0.04%,虽然目前小程序不多会兼容到这么低的版本,可是对一些有特殊须要的小程序也要注意基础库的差别。
另外要注意的是小程序并发请求的排队机制。当同时调用的请求超过 10 个时,小程序会先发起 10 个并发请求,超过 10 个的部分按调用顺序进行排队,当前一个请求完成时,再发送队列中的下一个请求。
附 20 个请求并发测试:
测试结果:
从图中能够看到,前 10 个请求同时发出,然后面的请求的起始点,对应了前面某个请求的结束点,能够反映出请求的排队行为。
这意味着,在并发请求不少的时候应该作好排队策略,按请求的重要程度和响应时间调整调用顺序,若是遇到请求的响应很慢的状况,能够考虑作 timeout
处理,以避免大量等待,影响用户体验。
搜索关注公众号「知晓云」,让你的小程序开发快人一步。