2013-10-22 12 views
14

मैं एक WCF वेब सेवा से डेटा प्राप्त कर रहा हूँ और जब डेटा से अधिक 0.2 मिलियन रिकॉर्ड है मैं एक अपवाद निम्नानुसार है जो मिलती है:System.ServiceModel.CommunicationException: अंतर्निहित कनेक्शन बंद कर दिया गया था

System.ServiceModel.CommunicationException: The underlying connection was closed: A connection that was expected to be kept alive was closed by the server. ---> System.Net.WebException: The underlying connection was closed: A connection that was expected to be kept alive was closed by the server. ---> System.IO.IOException: Unable to read data from the transport connection: An existing connection was forcibly closed by the remote host. ---> System.Net.Sockets.SocketException: An existing connection was forcibly closed by the remote host 
at System.Net.Sockets.Socket.Receive(Byte[] buffer, Int32 offset, Int32 size, SocketFlags socketFlags) 
at System.Net.Sockets.NetworkStream.Read(Byte[] buffer, Int32 offset, Int32 size) 
--- End of inner exception stack trace --- 
at System.Net.Sockets.NetworkStream.Read(Byte[] buffer, Int32 offset, Int32 size) 
at System.Net.PooledStream.Read(Byte[] buffer, Int32 offset, Int32 size) 
at System.Net.Connection.SyncRead(HttpWebRequest request, Boolean userRetrievedStream, Boolean probeRead) 
--- End of inner exception stack trace --- 
at System.Net.HttpWebRequest.GetResponse() 
at System.ServiceModel.Channels.HttpChannelFactory`1.HttpRequestChannel.HttpChannelRequest.WaitForReply(TimeSpan timeout) 
--- End of inner exception stack trace --- 

Server stack trace: 
at System.ServiceModel.Channels.HttpChannelUtilities.ProcessGetResponseWebException(WebException webException, HttpWebRequest request, HttpAbortReason abortReason) 
at System.ServiceModel.Channels.HttpChannelFactory`1.HttpRequestChannel.HttpChannelRequest.WaitForReply(TimeSpan timeout) 
at System.ServiceModel.Channels.RequestChannel.Request(Message message, TimeSpan timeout) 
at System.ServiceModel.Dispatcher.RequestChannelBinder.Request(Message message, TimeSpan timeout) 
at System.ServiceModel.Channels.ServiceChannel.Call(String action, Boolean oneway, ProxyOperationRuntime operation, Object[] ins, Object[] outs, TimeSpan timeout) 
at System.ServiceModel.Channels.ServiceChannelProxy.InvokeService(IMethodCallMessage methodCall, ProxyOperationRuntime operation) 
at System.ServiceModel.Channels.ServiceChannelProxy.Invoke(IMessage message) 

मेरे वेब .config इस तरह दिखता है:

<basicHttpBinding> 
    <binding name="BasicHttpBinding_IService" closeTimeout="00:01:00" openTimeout="00:01:00" receiveTimeout="00:10:00" sendTimeout="00:01:00" 
      maxBufferSize="2147483647" maxBufferPoolSize="2147483647" maxReceivedMessageSize="2147483647" 
      allowCookies="false" bypassProxyOnLocal="false" hostNameComparisonMode="StrongWildcard" 
      messageEncoding="Text" textEncoding="utf-8" transferMode="StreamedResponse" useDefaultWebProxy="true"> 
    <readerQuotas maxDepth="32" maxStringContentLength="2147483647" maxArrayLength="2147483647" 
        maxBytesPerRead="2147483647" maxNameTableCharCount="2147483647" /> 
    <security mode="None"> 
     <transport clientCredentialType="None" proxyCredentialType="None" realm="" /> 
     <message clientCredentialType="UserName" algorithmSuite="Default" /> 
    </security> 
    </binding> 
    <binding maxReceivedMessageSize="2147483647" allowCookies="true"> 
    <readerQuotas maxDepth="32" maxStringContentLength="2147483647" maxArrayLength="2147483647" maxBytesPerRead="2147483647" 
maxNameTableCharCount="2147483647" /> 
    </binding> 
</basicHttpBinding> 

मुझे यकीन है कि मेरी वेब सेवा डीबी से डेटा पुनर्प्राप्त कर रही है। लेकिन मैं अपने वेब पर स्थानांतरित करने में असमर्थ हूं जहां से मैंने कॉल शुरू किया था। किसी भी सहायता के लिए अग्रिम रूप से धन्यवाद।

+0

अपनी कॉन्फ़िगरेशन फ़ाइल में कनेक्शन टाइमआउट बढ़ाएं। – gleng

+0

WebBconfig –

उत्तर

15

मुझे हाल ही में एक .NET 4.0 वेब ऐप के भीतर एक डब्ल्यूसीएफ सेवा के साथ एक ही समस्या थी। मैंने maxItemsInObjectGraph मान बढ़ाया और सर्वर ने अपवाद फेंक दिया नहीं। प्रलेखन here कहते डिफ़ॉल्ट अधिकतम Int32.MaxValue है, लेकिन मुझे लगता है कि यह गलत है, अधिकतम मूल्य 65535.

<serviceBehaviors> 
    <behavior name="ServiceBehaviour"> 
     <dataContractSerializer maxItemsInObjectGraph="6553500"/> 
     <serviceMetadata httpGetEnabled="true" /> 
     <serviceDebug includeExceptionDetailInFaults="true" /> 
    </behavior> 
    </serviceBehaviors> 

है दूसरी बात आप कर सकते हैं का पता लगाने सक्षम है।

<system.diagnostics> 
    <sources> 
    <source name="System.ServiceModel" 
      switchValue="Information, ActivityTracing" 
      propagateActivity="true"> 
     <listeners> 
     <add name="traceListener" 
      type="System.Diagnostics.XmlWriterTraceListener" 
      initializeData= "c:\temp\log\Traces.svclog" /> 
     </listeners> 
    </source> 
    </sources> 
</system.diagnostics> 

यदि आप Traces.svclog पर डबल क्लिक करें, खिड़कियां खोल देना चाहिए माइक्रोसॉफ्ट सेवा ट्रेस दर्शक: यह है कि मैं क्या web.config में है का एक उदाहरण है।

यदि आप माइक्रोसॉफ्ट डब्ल्यूसीएफ टेस्ट क्लाइंट के साथ अपनी सेवा का परीक्षण करते हैं तो सुनिश्चित करें कि सर्वर सर्वर से प्रतिक्रिया प्राप्त करने के लिए सर्वर सेटिंग्स से मेल खाने के लिए आप डिफ़ॉल्ट क्लाइंट कॉन्फ़िगरेशन को बदल सकते हैं (इसमें क्लाइंट एंडपॉइंट व्यवहार शामिल है)।

मुझे उम्मीद है कि इससे मदद मिलती है।

+0

में उल्लिखित बाइंडिंग में maxBufferSize, maxReceivedMessageSize बढ़ाएं मुझे ओपी के समान समस्या थी, '>> मेरे लिए समस्या तय की गई। –

+1

मुझे भी एक ही समस्या थी। सेवा tracelog का उपयोग करके मुझे अपने डीटीओ कक्षा की एक क्रमबद्धता त्रुटि मिली है ... – GiveEmTheBoot

+0

लिंक में प्रलेखन सिस्टम के लिए है। रनटाइम। क्रमबद्धता वर्ग। सेवा व्यवहार का लिंक यहां दिया गया है, जो अधिकतम दिखाता है कि अधिकतम 65536 http://msdn.microsoft.com/en-us/library/ms731809(v=vs.100).aspx – mmeasor

2

अपने क्लाइंट को मूलभूत बनाएं अपने सर्वर बाध्यकारी के समान ही बाध्यकारी करें। सर्वर और क्लाइंट बाध्यकारी के बजाय केवल एक बाध्यकारी बदलने के लिए यह एक सामान्य सामान्य त्रुटि है।

कि नहीं आप WCF ट्रेसिंग सक्षम कर सकते हैं काम करता है: wcf tracing

कि तुम क्या छोटा सा अफसर समस्या है में और अधिक जानकारी देगा।

0

हमारे पास हमारे ऑब्जेक्ट ग्राफ़ में एक लूप था जो लौट रहा था। मुझे पता है कि यह शायद आपकी समस्या नहीं है लेकिन अगर मैं किसी और के पास एक ही समस्या है तो मैं इसे यहां जोड़ रहा हूं। हमने एक्सेप्शनडिंटइनफॉल्ट सक्षम किया था लेकिन किसी भी क्लाइंट (हमारे एप्लिकेशन या डब्ल्यूसीएफ टेस्ट क्लाइंट) में त्रुटि नहीं मिली थी। सौभाग्य से यह सर्वर लॉग में दिखाई दिया ताकि हम इसे इस तरह से ढूंढ सकें।

हमारे पास दो-तरफा नेविगेशन के लिए माता-पिता -> बच्चे और बच्चे -> माता-पिता थे, हमें उस लिंक को तोड़ना पड़ा और इसके बजाय माता-पिता -> बच्चे, और बच्चे के पास माता-पिता को देखने के लिए एक आईडी थी, तो त्रुटि हुई दूर।

उम्मीद है कि यह किसी की मदद करेगा!

0

अपनी डब्ल्यूसीएफ सेवा कॉन्फ़िगरेशन में निम्न कॉन्फ़िगरेशन जोड़ें। और सी: \ log \ Traces.svclog फ़ाइल देखें। मेरा अपवाद फेंक दिया गया था;

पैरामीटर क्रमानुसार करने InnerException संदेश 'Enum मान' 0 था की कोशिश करते समय एक त्रुटि हुई थी 'प्रकार के लिए अमान्य है' ThyCams2014.XrmBase.new_filingstatu 'और धारावाहिक नहीं किया जा सकता। सुनिश्चित करें कि आवश्यक enum मान मौजूद हैं और यदि EncMemberAttribute विशेषता के साथ चिह्नित किया गया है, तो इस प्रकार डेटाकंट्रैक्टएट्रिब्यूट एट्रिएंटर कोड यहाँ है। '। अधिक जानकारी के लिए कृपया इनरएक्सप्शन देखें।

<configuration> 
    <system.diagnostics> 
     <sources> 
      <source name="System.ServiceModel" 
        switchValue="Information, ActivityTracing" 
        propagateActivity="true"> 
      <listeners> 
       <add name="traceListener" 
        type="System.Diagnostics.XmlWriterTraceListener" 
        initializeData= "c:\log\Traces.svclog" /> 
      </listeners> 
     </source> 
     </sources> 
    </system.diagnostics> 
</configuration> 
संबंधित मुद्दे

 संबंधित मुद्दे