c# – GetRequestStream随机抛出超时异常
发布时间:2020-12-15 06:44:09 所属栏目:百科 来源:网络整理
导读:经过几天的搜索,我真的无法解决所描述的问题.希望这里会找到一个解决方案 在同一服务器上调用WCF服务时,我使用附加的代码.我在调用WebReq.GetRequestStream()时随机获取超时错误 当我检查netstat时,我看到连接保持打开状态,所以可能有问题,但是我不知道如何
经过几天的搜索,我真的无法解决所描述的问题.希望这里会找到一个解决方案
在同一服务器上调用WCF服务时,我使用附加的代码.我在调用WebReq.GetRequestStream()时随机获取超时错误 当我检查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,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秒的空闲时间之后抛出,而且在这行中还有五个左右的请求.真的找不到一个模式. 这段代码可能是错的?是否有其他(更好)的方式调用WCF服务? 解决方法
我不知道这对问题一定是负责的,但是如果没有引发异常,那么你只是关闭Web响应,并且你从不关闭响应流.使用语句:
using (HttpWebResponse response = (HttpWebResponse)request.GetResponse()) using (StreamReader reader = new StreamReader(response.GetResponseStream())) { return reader.ReadToEnd(); } 这可以很好地解释问题,就像您打开响应一样,它将保持与Web服务器的连接打开 – 这意味着连接池无法使用该连接. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
推荐文章
站长推荐
热点阅读