我目前正在运行一个脚本,该脚本在很长一段时间内命中 api 大约 3000 次。我正在使用 parallel.foreach((,以便我可以一次发送几个请求以加快该过程。我在每个迭代中创建两个请求,因此我的请求不应超过 10 个。我的问题是,我不断收到来自服务器的 429 错误,我与管理服务器的人交谈,他们说他们看到的请求是 40+ 的突发。以我目前对我的代码的理解,我不相信这是不可能的,如果我在这里遗漏了什么,有人可以让我知道吗?
public static List<Requests> GetData(List<Requests> requests)
{
ParallelOptions para = new ParallelOptions();
para.MaxDegreeOfParallelism = 5;
Parallel.ForEach(requests, para, request =>
{
WeatherAPI.GetResponseForDay(request);
});
return requests;
}
public static Request GetResponseForDay(Request request)
{
var request = WebRequest.Create(request);
request.Timeout = 3600000;
HttpWebResponse response = (HttpWebResponse)request.GetResponse();
StreamReader myStreamReader = new
StreamReader(response.GetResponseStream());
string responseData = myStreamReader.ReadToEnd();
response.Close();
var request2 WebRequest.Create(requestthesecond);
HttpWebResponse response2 = (HttpWebResponse)request2.GetResponse();
StreamReader myStreamReader2 = new
StreamReader(response2.GetResponseStream());
string responseData2 = myStreamReader2.ReadToEnd();
response2.Close();
DoStuffWithData(responseData, responseData2)
return request;
}
正如 Smartobelix 指出的那样,将并行度设置为 5 并不能阻止您发送服务器端策略定义的太多请求。 它所做的只是防止您耗尽在您这边发出这些请求所需的线程数。 因此,您需要做的是与服务器所有者沟通,熟悉其限制并更改代码以永不达到限制。
涉及的变量包括:
- 将发送的并发请求数(并行度(
- 一个请求花费的平均时间
- 服务器允许的每单位时间的最大请求数
因此,例如,如果您的平均请求时间为 200 毫秒,并且您的最大并行度为 5,那么您可以期望平均每秒发送 25 个请求。 如果每个请求需要 500 毫秒,那么您将只发送 10 个。
将服务器允许的数字混合到其中,您将了解如何微调您的数字。
上面的两个答案基本上都是正确的。我遇到的问题是服务器管理器将速率限制设置为 100 个请求/分钟,而以前没有一个请求并且没有通知我。一旦我达到 100 个请求/分钟的限制,我几乎立即开始收到 429 个错误,并开始以这种速度发出请求,这些请求也收到了 429 个错误。