Parallel.foreach() with WebRequest. 429 error



我目前正在运行一个脚本,该脚本在很长一段时间内命中 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 并不能阻止您发送服务器端策略定义的太多请求。 它所做的只是防止您耗尽在您这边发出这些请求所需的线程数。 因此,您需要做的是与服务器所有者沟通,熟悉其限制并更改代码以永不达到限制。

涉及的变量包括:

  1. 将发送的并发请求数(并行度(
  2. 一个请求花费的平均时间
  3. 服务器允许的每单位时间的最大请求数

因此,例如,如果您的平均请求时间为 200 毫秒,并且您的最大并行度为 5,那么您可以期望平均每秒发送 25 个请求。 如果每个请求需要 500 毫秒,那么您将只发送 10 个。

将服务器允许的数字混合到其中,您将了解如何微调您的数字。

上面的两个答案基本上都是正确的。我遇到的问题是服务器管理器将速率限制设置为 100 个请求/分钟,而以前没有一个请求并且没有通知我。一旦我达到 100 个请求/分钟的限制,我几乎立即开始收到 429 个错误,并开始以这种速度发出请求,这些请求也收到了 429 个错误。

最新更新