GetRequestStream随机抛出Timeout异常

Anz*_*zeR 9 c# asp.net wcf timeout httpwebrequest

谷歌搜索了几天后,我真的无法解决所描述的问题.希望这里能找到解决方案

我在同一台服务器上调用WCF服务时使用附加代码.我在调用WebReq.GetRequestStream()中随机获得Timeout错误

当我检查netstat时,我看到连接仍然打开,所以可能有问题,但我不知道如何解决它

       //request inicialization
        HttpWebRequest WebReq = (HttpWebRequest)WebRequest.Create(url);
        WebReq.Method = "POST";
        WebReq.ContentType = "application/json; charset=utf-8";
        WebReq.ContentLength = buffer.Length;

        WebReq.Proxy = null;
        WebReq.KeepAlive = false; //also tried with true
        WebReq.AllowWriteStreamBuffering = false; //also tried with true

        //this produces an error
        using (Stream PostData = WebReq.GetRequestStream())
        {
            PostData.Write(buffer, 0, buffer.Length);
            PostData.Close();
        }

         //open and read response
         HttpWebResponse WebResp = (HttpWebResponse)WebReq.GetResponse();
         Stream Answer = WebResp.GetResponseStream();
         StreamReader _Answer = new StreamReader(Answer);

         WebResp.Close();

         //return string
         return _Answer.ReadToEnd();
Run Code Online (Sandbox Code Playgroud)

超时是在大约10秒的空闲时间之后抛出的,但也是在行中有5个左右的请求之后.真的找不到模式.

这段代码有什么问题?有没有其他(更好的)方式来调用WCF服务?

Jon*_*eet 13

我不知道它肯定对这个问题负责,但是如果它没有抛出异常,你只关闭web响应,并且你永远不会关闭响应流.使用using陈述:

using (HttpWebResponse response = (HttpWebResponse)request.GetResponse())
using (StreamReader reader = new StreamReader(response.GetResponseStream()))
{
    return reader.ReadToEnd();
}
Run Code Online (Sandbox Code Playgroud)

这可以很好地解释这个问题,就好像你打开一个响应一样,它将保持与Web服务器的连接打开 - 这意味着连接池然后就不能使用该连接.


Chr*_*tow 6

我有同样的问题,添加对HttpWebRequest.Abort()的调用似乎解决了它.