GetRequestStream随机抛出Timeoutexception

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

我在同一台服务器上调用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(); 

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

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

我不知道它肯定是问题的原因,但是如果它没有抛出exception,你只关闭web响应,并且你永远不会关闭响应流。 使用using语句:

 using (HttpWebResponse response = (HttpWebResponse)request.GetResponse()) using (StreamReader reader = new StreamReader(response.GetResponseStream())) { return reader.ReadToEnd(); } 

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

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

因为这是非常奇怪的行为,我想知道是否有任何其他方法来调用WCF服务,托管在同一个IIS服务器上。 我还有一点,那就是为这种调用创建TCP连接并没有真正优化,所有其他方法都应该快得多。

要记住的第一件事是检查发送的URI,参数和标头,具体来说:

  • 保留字符。 通过URI发送保留字符会带来问题! * ' ( ) ; : @ & = + $ , / ? # [] ! * ' ( ) ; : @ & = + $ , / ? # []
  • URI长度:不应超过2000个字符
  • 长度标头:大多数Web服务器确实限制了它们接受的标头大小。 例如在Apache中,默认限制为8KB。

请记住,如果要从较长的长度发送数据,建议在邮件正文中发送。