Golang 請求限速、排隊實現
概要
在調用第三方 API 的時候, 基本都有訪問限速的限制條件. 第三方的 API 有多個的時候, 就不太好控制訪問速度, 常常會導致 HTTP 429(Too Many Requests) 然后就會有一段時間的禁止訪問.
為了應對這種限速的情況, 通過一個簡單的請求隊列來控制訪問的速度, 之后基本沒遇到過 HTTP 429 了.
實現思路
首先, 每個請求包裝成一個?RequestParam?的 struct, 其中包含請求的地址,類型,參數以及 response 的 channel.
發送請求的時候, 只要將?RequestParam?放入請求隊列中即可, 請求完成后, 將 response 放入對應的 channel 中.
整個代碼實現很簡單:
這里的請求是用了我自己封裝的 apiclient, 可以根據實際情況替換.
在我的應用場景里, 只要 api 順序訪問就不會出現 HTTP 429 了, 如果這樣覺得速度太快的的話, 可以嘗試在?Run()?函數中加入一些時間間隔.
使用方法
使用很簡單, 首先啟動, 然后每個調用的地方將?RequestParam?放入隊列并等待 response 即可.
啟動隊列服務
使用隊列服務
鏈接:https://www.cnblogs.com/wang_yb/p/13018901.html
(版權歸原作者所有,侵刪)