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服务器的连接打开 - 这意味着连接池然后就不能使用该连接.
归档时间: |
|
查看次数: |
15643 次 |
最近记录: |