這可能是一個冷訊息,所以標題比較勁爆。
小程式併發限制由來已久,從剛釋出時的 5 併發,到後來的 10 併發,同時發出的請求數若超出這個限制則將被殘忍拋棄,由此催生了很多開發者在自己的專案中造了「請求排隊」的輪子。然而事實上,早在一年半以前,該限制就被微信官方取消。
10 個請求的併發限制
關於併發限制,微信開發者文件中是這麼寫的:
這一限制的意思是在同一時刻, wx.request
、wx.uploadFile
、wx.downloadFile
加起來的併發總數不能超出 10 個。
至今,仍有很多開發者一直遵守著這個規則。
許多人在寫業務的時候小心翼翼地維護著請求數。為了將請求數控制好,特地將一些並行請求改為序列,或者引入請求佇列來維護小程式請求。
這部分資深開發者為了遵守這一規則所花的功夫,多少反映出了早年他們在面對數額超出後請求被殘忍拋棄時的無奈。
附小程式基礎庫版本 1.3.0 的控制檯報錯:
時至今日,仍有開發者在討論解決小程式併發限制的方法:
被忽略的訊息
實際上,微信在 2017 年 7 月的基礎庫 1.4.0 版本升級中就做了優化,對超過併發限制的請求做了佇列處理,只是還有很多開發者並不知道這一訊息。
從嚴格意義上來說,此次優化並沒有完全解除原有的併發限制。目前同時處理請求的上限仍是 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
處理,以免大量等待,影響使用者體驗。
搜尋關注公眾號「知曉雲」,讓你的小程式開發快人一步。