System.Net.WebException: время ожидания операции истекло

У меня есть сложный код, в одном разделе я отправляю оставшийся веб-запрос в веб-службу и получаю его ответ для остальной части задания, ответ имеет размер варианта, иногда он тяжелый, в IIS Express на VS нет никаких проблем, но при запуске в IIS выдается System.Net.WebException: время ожидания операции истекло. и это код, который я использую:

  Dim req As HttpWebRequest = TryCast(WebRequest.Create("http://www.somedomain.com/service.svc"), HttpWebRequest)
        Using TryCast(req, IDisposable)
            req.Proxy = Nothing
            req.ServicePoint.ConnectionLimit = 100
            req.ServicePoint.MaxIdleTime = 3000000
            req.Method = "POST"
            req.Headers("Accept-Encoding") = "gzip,deflate"
            req.ContentType = "application/soap+xml; charset=UTF-8"

            If compressionRequested = True Then
                ''  if you want to receive compressed response 

                req.Headers.Add("Accept-Encoding", "gzip, deflate")
            End If
            Dim stOut As New StreamWriter(req.GetRequestStream(), System.Text.Encoding.ASCII)

            stOut.Write(xml.ToString)
            stOut.Close()


            Using resp As HttpWebResponse = DirectCast(req.GetResponse(), HttpWebResponse)
                If resp.ContentEncoding = "gzip" Then


                    Dim st As Stream = resp.GetResponseStream()
                    If resp.ContentEncoding.ToLower().Contains("gzip") Then
                        st = New System.IO.Compression.GZipStream(st, System.IO.Compression.CompressionMode.Decompress)
                    ElseIf resp.ContentEncoding.ToLower().Contains("deflate") Then
                        st = New System.IO.Compression.DeflateStream(st, System.IO.Compression.CompressionMode.Decompress)
                    End If
                    Dim bfst As BufferedStream = New BufferedStream(st)
                    Using stIn As New StreamReader(bfst, Encoding.[Default])
                        respXml = stIn.ReadToEnd()


                        stIn.Close()
                    End Using

                Else
                    Using stIn As New StreamReader(resp.GetResponseStream())
                        respXml = stIn.ReadToEnd()

                        stIn.Close()
                    End Using
                End If
            End Using

        End Using

также в web.config я настроил это:

<system.net>
<connectionManagement>
        <add address="*" maxconnection="100" />
        </connectionManagement>
    <settings>
      <servicePointManager expect100Continue="true" />
    </settings>
  </system.net>

Есть ли какие-либо предложения, где проблема и как ее решить?


person arash rajaei    schedule 13.09.2015    source источник


Ответы (1)


Добавляя GC.Collect() перед этим кодом, все работает нормально,

person arash rajaei    schedule 23.07.2016