System.Net.WebException: The request was aborted: the request was cancelled

前端 未结 5 486
余生分开走
余生分开走 2021-02-04 06:45

I have a WCF service that has been giving me this error under load conditions (and I can\'t seem to recreate the error otherwise). We\'ve been trying to find a way around it for

相关标签:
5条回答
  • 2021-02-04 07:29

    I had this exact same problem. In my case I was executing requests ASynchronously. I was sending a few hundred requests to the 'server' from my client. I am/was using basicHttpBinding. And in my app.config setting the openTimeout property was set to 60 seconds or one minute. Once I set that to a bigger number like 10 minutes, the problem has gone away.

    So for instance I changed all these values in my app.config file:

    <configuration>
        <system.serviceModel>
            <bindings>
                <basicHttpBinding>
                    <binding name="BasicHttpBinding_IScriptRunHost" closeTimeout="00:10:00"
                        openTimeout="00:10:00" receiveTimeout="00:10:00" sendTimeout="00:10:00"
    

    to 10 minutes.

    0 讨论(0)
  • 2021-02-04 07:38

    I don't think that HTTP keep alive is responsible for this. WCF should be able to handle this by itself so the HTTP persistant connection is shared among requests and if it expires (it expires after 100s of inactivity) WCF creates new one without firing any exception. If your connection is aborted during request transmission then I expect there will be some other problem.

    You can use this custom binding as equivalent to BasicHttpBinding without HTTP keep alive:

    <bindings>
      <customBinding>
        <binding name="NoKeepAlive">
          <textMessageEncoding messageVersion="Soap11" />
          <httpTransport keepAliveEnabled="false" />
        </binding>
      </customBinding>
    </bindings> 
    
    0 讨论(0)
  • 2021-02-04 07:38

    I had this problem when trying to upload large files. I had to add this to the web.config of the web services

    <system.web>
      <httpRuntime maxRequestLength="10240" />
    
    0 讨论(0)
  • 2021-02-04 07:40

    This error can also be caused by mixing using clauses with asynchronous calls to WCF services.

    For example:

    using (ServiceClient proxy = new ServiceClient(proxyName)) {
      proxy.Open();
      return proxy.FunctionCallAsync(parameters); //Return type being Task<ResultSet>
    }
    

    This will trigger a race condition between how fast can it dispose of proxy versus how fast the asynchronous Task<ResultSet> can be completed. Longer the task takes the more likely it will be to end up in a Faulted state and the Result containing a System.ServiceModel.CommunicationException.

    This can be fixed by removing the using clause:

    ServiceClient proxy = new ServiceClient(proxyName))
    proxy.Open();
    return proxy.FunctionCallAsync(parameters); //Return type being Task<ResultSet>
    

    Note that proxy should be persisted too so that once the asynchronous call is completed that a proxy.Close() can be done.

    0 讨论(0)
  • 2021-02-04 07:49

    add this in app.config

     <system.net>
     <connectionManagement>
          <add address="*" maxconnection="5"/>
                    <add address="https://api.limitedconnections.com*" maxconnection="2"/>                
                    <add address="https://api.moreconnections.com*" maxconnection = "10"/>
            </connectionManagement>
    </system.net>
    

    Refer the below link

    https://cdijkgraaf.wordpress.com/2019/12/02/configuring-maxconnection-in-biztalk/

    0 讨论(0)
提交回复
热议问题