2013-03-28 3 views
1

Я использую службы WCF в проекте WPF. У меня большой объем данных, около 847 000 записей в таблице. это исключение бросили на стороне клиентаПодключенное соединение было закрыто: соединение было неожиданно закрыто wcf

В VM

proxy.ServicesClient client = new proxy.ServicesClient(); 
var result = client.GetCustomers(); // here throws ('ComunicationException was unhandled by user code: The underlying connection was closed: The connection was closed unexpectedly.') 

В App.config

<?xml version="1.0" encoding="utf-8" ?> 
<configuration> 
    <system.serviceModel> 
     <bindings> 
     <basicHttpBinding> 
      <binding name="BasicHttpBinding_IServices" closeTimeout="00:10:00" 
       openTimeout="00:10:00" receiveTimeout="00:10:00" sendTimeout="00:10:00" 
       maxBufferSize="2147483647" maxReceivedMessageSize="2147483647"> 
      <security mode="None" /> 
      </binding> 
     </basicHttpBinding> 
     </bindings> 
     <behaviors> 
     <endpointBehaviors> 
      <behavior name="clientBehavior"> 
      <dataContractSerializer maxItemsInObjectGraph="2147483647" /> 
      </behavior> 
     </endpointBehaviors> 
     </behaviors> 
     <client> 
      <endpoint address="http://localhost:7902/WpfStoreService.svc" 
       binding="basicHttpBinding" bindingConfiguration="BasicHttpBinding_IServices" 
       contract="proxy.IServices" name="BasicHttpBinding_IServices" behaviorConfiguration="clientBehavior" /> 
     </client> 
    </system.serviceModel> 
</configuration> 

В Web.Config

<?xml version="1.0"?> 
<configuration> 

    <connectionStrings> 
    <add name="AdventureWorksLTConnectionString" connectionString="Data Source=.;Initial Catalog=AdventureWorksLT;Integrated Security=True;" /> 
    </connectionStrings> 

    <system.web> 
    <compilation debug="true" targetFramework="4.0" /> 
    </system.web> 

    <system.serviceModel>  

    <bindings> 
     <basicHttpBinding>  
     <binding name="BasicHttpBinding_IServices" receiveTimeout="00:10:00" sendTimeout="00:10:00" openTimeout="00:10:00" closeTimeout="00:10:00" 
       maxReceivedMessageSize="2147483647" 
       maxBufferSize="2147483647" 
       maxBufferPoolSize="2147483647"> 
      <readerQuotas maxDepth="2147483647" 
         maxStringContentLength="2147483647" 
         maxArrayLength="2147483647" 
         maxBytesPerRead="214748364" 
         maxNameTableCharCount="2147483647"/> 

      <security mode="None"/> 
     </binding> 

     </basicHttpBinding> 
    </bindings> 

    <services> 
     <service name="WpfStore.Services.Services" behaviorConfiguration="debugbehavior"> 
     <endpoint address="" binding="basicHttpBinding" contract="WpfStore.Services.Contracts.IServices" bindingConfiguration="BasicHttpBinding_IServices"/> 
     </service> 
    </services> 

    <behaviors> 
     <serviceBehaviors> 
     <behavior name="debugbehavior"> 
      <serviceMetadata httpGetEnabled="true"/> 
      <serviceDebug includeExceptionDetailInFaults="false"/> 
      <dataContractSerializer maxItemsInObjectGraph="2147483647"/> 
     </behavior> 
     </serviceBehaviors> 
    </behaviors> 
    <serviceHostingEnvironment multipleSiteBindingsEnabled="true" /> 
    </system.serviceModel> 
<system.webServer> 
    <modules runAllManagedModulesForAllRequests="true"/> 
    </system.webServer> 
</configuration> 

Примечание: 1. It доза не работает с большим объемом данных. В этом случае у меня около 847 000 записей в таблице. Он отлично работает с небольшими данными (около 5000 - 6000 записей). 2. Я отлаживаю его и всю запись, полученную с SQL-сервера, на мой DAL; Это исключение увеличивается в течение 5-10 секунд после того, как я вызываю от клиента эту служебную функцию.

+4

Вы серьезно отправляете 847000 записей по проводам? возможно, вам стоит подумать об использовании пейджинга? – failedprogramming

+0

Я просто протестировал, он не работал 7000 записей тоже – user746499

+0

Почему бы вам не проследить его. http://stackoverflow.com/q/4271517/413032 Большинство проблем такого типа можно решить путем трассировки. Кажется, ваше соединение потеряно. –

ответ

Смежные вопросы