Почему следующий код Тайм-аут второго (и последующего) времени его запуска?
Код висит на:
using (Stream objStream = request.GetResponse().GetResponseStream())
а затем вызывает сообщение WebException о том, что запрос истекает.
Я пробовал это с помощью WebRequest
и HttpWebRequest
Изменить: кажется, что код падает в request.GetResponse()
Изменить: этот пост предполагает, что это может быть проблема с GC → http://www.vbforums.com/showthread.php?t=610043 - в соответствии с этим постом проблема смягчается, если Fiddler открыта в фоновом режиме.
Сервер доступен и доступен для запросов.
private string GetQLMResponse(string URL)
{
HttpWebRequest request = WebRequest.Create(URL) as HttpWebRequest;
request.Credentials = new NetworkCredential(Settings.Default.LicenseUser, Settings.Default.LicensePassword);
request.KeepAlive = false;
request.Timeout = 5000;
request.Proxy = null;
// Read stream
string responseString = String.Empty;
try
{
using (var response = request.GetResponse())
{
using (Stream objStream = response.GetResponseStream())
{
using (StreamReader objReader = new StreamReader(objStream))
{
responseString = objReader.ReadToEnd();
objReader.Close();
}
objStream.Flush();
objStream.Close();
}
response.Close();
}
}
catch (WebException ex)
{
throw new LicenseServerUnavailableException();
}
finally
{
request.Abort();
request = null;
GC.Collect();
}
return responseString;
}
Thrown WebException:
{ "Операция завершена" } [System.Net.WebException]: { "Время выполнения операции" } Данные: {System.Collections.ListDictionaryInternal} HelpLink: null InnerException: null Сообщение: "Операция завершена" Источник: "Система" StackTrace: "в System.Net.HttpWebRequest.GetResponse()\r\n на IQX.Licensing.License.GetQLMResponse(String URL) в C:\Users\jd\SVN\jd\Products\Development\JAD.Licensing\JAD.Licensing\License.cs: строка 373" TargetSite: {System.Net.WebResponse GetResponse()}
Обновление: ОК Итак, теперь работает следующий код. СервисPoint установил таймаут около 4 минут. Изменение ServicePoint.ConnectionLeaseTimeout
объекта запроса означает, что запрос теперь уничтожен после 5000 мс. Спасибо всем за вашу помощь, а также за эти 2 страницы:
- http://blogs.msdn.com/b/adarshk/archive/2005/01/02/345411.aspx
-
http://msdn.microsoft.com/en-us/library/6hszazfz(v=VS.80).aspx
private string GetQLMResponse(string URL) { HttpWebRequest request = WebRequest.Create(URL) as HttpWebRequest; request.Credentials = new NetworkCredential(Settings.Default.LicenseUser, Settings.Default.LicensePassword); request.KeepAlive = false; request.Timeout = 5000; request.Proxy = null; request.ServicePoint.ConnectionLeaseTimeout = 5000; request.ServicePoint.MaxIdleTime = 5000; // Read stream string responseString = String.Empty; try { using (WebResponse response = request.GetResponse()) { using (Stream objStream = response.GetResponseStream()) { using (StreamReader objReader = new StreamReader(objStream)) { responseString = objReader.ReadToEnd(); objReader.Close(); } objStream.Flush(); objStream.Close(); } response.Close(); } } catch (WebException ex) { throw new LicenseServerUnavailableException(); } finally { request.Abort(); } return responseString; }