HTTPS呼叫未连接到服务器

时间:2020-03-04 06:45:25

标签: c# .net rest http windows-services

我正在Visual Studio 2017中研究ONLY_FULL_GROUP_BY。在其余api的调用中,在调试代码时获取异常。有时在收到异常之后,前2 3个电话会起作用。

System.Net.WebException:'远程服务器返回错误:(503) 服务器不可用。'

远程服务器返回错误:(429)

无法连接到远程服务器

从Postman调用相同的api时,成功获得响应。

这是我的代码

Windows Service

以上代码中使用的方法

private void timer1_Tick(object sender, ElapsedEventArgs e)
{
    WriteToFile("timer1_Tick method called..");
try
{
    string jsonString = "";
    string jsonstring2 = "";
    string prodfetchurl = HOST;
    var req = WebRequest.Create(prodfetchurl) as HttpWebRequest;
    req.Method = "GET";
    InitializeRequest(req);
    req.Accept = MIME_TYPE;
    //System.Threading.Thread.Sleep(5000);
    var response = (HttpWebResponse)req.GetResponse();
    WriteToFile("First service called...");
    if (response.StatusCode == HttpStatusCode.OK)
    {
        Stream responseStream = response.GetResponseStream();
        StreamReader responseReader = new StreamReader(responseStream);
        jsonString = responseReader.ReadToEnd();
    }
    var deserialsseobj = JsonConvert.DeserializeObject<ProductList>(jsonString).Products.Where(i => i.Failed > 0).ToList();
    foreach (var a in deserialsseobj)
    {
        var pid = a.ID;
        string url = FailedDevicesUrl + pid.Value + "/failed";
        var req2 = WebRequest.Create(url) as HttpWebRequest;
        req2.Method = "GET";
        InitializeRequest(req2);

        req2.Timeout = 300000;
        req2.Accept = MIME_TYPE;
        var response1 = (HttpWebResponse)req2.GetResponse();
        Stream responsestream2 = response1.GetResponseStream();
        WriteToFile("Second service called...");
        if (response1.StatusCode == HttpStatusCode.OK)
        {
            StreamReader responsereader1 = new StreamReader(responsestream2);
            jsonstring2 = responsereader1.ReadToEnd();
        }

        var output = JsonConvert.DeserializeObject<List<FailedDeviceList>>(jsonstring2);  // Will get List of the Failed devices
        List<int> deviceids = new List<int>();
        Reprocessdata reproc = new Reprocessdata();
        Reprocessdata.DeviceId rprod = new Reprocessdata.DeviceId();

        reproc.ForceFlag = true;
        reproc.ProductID = pid.Value;
        foreach (var dd in output)
        {
            rprod.ID = dd.DeviceId;
            reproc.DeviceIds.Add(rprod);
        }

        // Reprocess the Product in Devices
        var req3 = WebRequest.Create(ReprocessUrl) as HttpWebRequest;
        req3.Method = "POST";
        InitializeRequest(req3);
        req3.Accept = MIME_TYPE;
        req3.Timeout = 300000;
        req3.ContentType = "application/json";
        using (StreamWriter writer = new StreamWriter(req3.GetRequestStream()))
        {
            string json = new JavaScriptSerializer().Serialize(reproc);

            writer.Write(json);
            writer.Close();
        }
        System.Threading.Thread.Sleep(5000);
        var response5 = (HttpWebResponse)req3.GetResponse();
        WriteToFile("Third service called...");
        if (response5.StatusCode == HttpStatusCode.OK)
        {
            string result;
            using (StreamReader rdr = new StreamReader(response5.GetResponseStream()))
            {
                result = rdr.ReadToEnd();
            }
        }
    }
    response.Close();
}
catch (Exception ex)
{
    WriteToFile("Simple Service Error on: {0} " + ex.Message + ex.StackTrace);
}
}

当我联系服务提供商时,他们说那里的一切都很好。这是我的代码有错误还是Windows服务不可靠?我该如何解决这个问题?

注意:使用Visual Studio Code,Angular应用程序中的所有API都可以正常工作。这意味着我的代码无法正常工作。

编辑1::我正在使用来自this document的VMware的以下三个服务。

protected override void OnStart(string[] args)
{
    base.OnStart(args);
    timer1 = new System.Timers.Timer();
    timer1.Interval = 60000; //every 1 min
    timer1.Elapsed += new System.Timers.ElapsedEventHandler(timer1_Tick);
    timer1.Enabled = true;
    WriteToFile("Service has started..");
}

public void InitializeRequest(HttpWebRequest request)
{
    request.Headers.Add("aw-tenant-code", API_TENANT_CODE);
    request.Credentials = new NetworkCredential(USER_NAME, PASSWORD);
    request.KeepAlive = false;
    request.AddRange(1024);
}

2 个答案:

答案 0 :(得分:4)

响应http代码429表示您在目标Web服务上发送太多请求

这意味着您尝试发送请求的服务具有一项策略,该策略会按时间限制限制某些请求。

我也承认可以手动配置外部服务,以在您不知道的特定情况下抛出403代码。如果是这样,则可以在外部服务文档中说明此信息...:em

您可以做什么?

适合限制
您可以详细研究目标Web服务的局限性,并设置代码以适应此局限性。例如,如果服务受到限制,即每10分钟仅接收一个请求-您必须将计时器设置为每10分钟或更长时间发送一个请求。如果文档中没有提供此类信息-您可以通过查找一些带有外部服务响应的模式来进行手动测试。

使用代理
每个限制策略均基于有关请求发送者的信息。 通常该信息仅包含发送者的IP地址。这意味着,如果您从两个不同的IP地址发送2个请求-限制策略将认为就像2个不同的计算机发送这些请求一样。因此,您可以在目标Web服务器上查找/购买/租用一些代理IP地址并通过该地址发送请求。

如何使用this答案中的WebRequest通过C#代理连接。

与外部服务提供商进行协商
如果您有可能与外部服务开发人员或帮助中心进行通信,则可以要求他们减少对IP地址的限制(如果它是静态的),或者提供一些机制来避免使用限制策略。如果由于某种原因他们不能提供此机会,至少您可以询问有关限制的详细信息。

重复机制
有时候,您收到的外部错误 503 错误代码可能是由于服务不可用引起的。这意味着服务器可以处于维护状态或暂时超载。因此,您可以编写重复机制来向服务器连续发送请求,直到服务器可以访问为止。

Polly库可能会帮助您创建重复机制

答案 1 :(得分:3)

该503的内部错误是:

远程服务器返回错误:(429)

HTTP 429指示请求太多。也许您的上游服务器无法处理所有发送的请求。

如果您正在调用第三方API,则在达到速率限制/限制值时可能会发生这种情况。

更新

按照API文档第28页,您可以在创建新API时配置限制。检查节流阀是否太小或关闭节流阀,看看是否可以解决错误?

enter image description here