[英]Increasing timeout for WCF web service in c#
我目前有一個應用程序在服務器上調用Web服務進行搜索。 我們可以期待返回大量數據,因此搜索花費的時間超過一分鍾是常規的。
對於如此大量的搜索,我們一直在收到以下錯誤消息:
在00:00:59.7350618之后等待回復時,請求通道超時。 增加傳遞給Request的調用的超時值或增加Binding上的SendTimeout值。 分配給此操作的時間可能是較長超時的一部分。
這是我們在StackOverflow上發布的多個問題中看到的問題,遺憾的是,沒有一個可用的解決方案幫助我解決問題,甚至無法配置超時窗口。
我們都改變了客戶端的app.config,增加了所有超時(CloseTimeout,OpenTimeout,ReceiveTimeout和SendTimeout)以及服務器上服務的所有web.config值(closeTimeout,openTimeout和SendTimeout)。
這些變化都沒有任何影響,我仍然收到分鍾超時。 知道為什么改變這些值會產生影響嗎?
在下面的示例中,我們縮短了時間,使我們不必在測試期間等待整整一分鍾。
Web.config文件:
<configuration>
<system.web>
<compilation targetFramework="4.0" />
</system.web>
<system.diagnostics>
<trace autoflush="true" />
<sources>
<source name="System.Net">
<listeners>
<add name="TraceFile" />
</listeners>
</source>
<source name="System.Net.Sockets">
<listeners>
<add name="TraceFile" />
</listeners>
</source>
</sources>
<sharedListeners>
<add name="TraceFile" type="System.Diagnostics.TextWriterTraceListener"
initializeData="trace.log" />
</sharedListeners>
<switches>
<add name="System.Net" value="Verbose" />
<add name="System.Net.Sockets" value="Verbose" />
</switches>
</system.diagnostics>
<system.serviceModel>
<diagnostics>
<messageLogging logMalformedMessages="false" logMessagesAtServiceLevel="false"
logMessagesAtTransportLevel="false" />
</diagnostics>
<services>
<service behaviorConfiguration="SearchIndexServiceBehavior" name="SearchIndex.Service">
<endpoint address="" binding="basicHttpBinding" contract="ISearchIndexServices" />
<host>
<timeouts closeTimeout="00:00:10" />
</host>
</service>
</services>
<bindings>
<basicHttpBinding>
<binding closeTimeout="00:00:10" openTimeout="00:00:15" sendTimeout="00:00:20"
receiveTimeout="00:00:25" maxBufferSize="2147483647" maxBufferPoolSize="2147483647"
maxReceivedMessageSize="2147483647">
<readerQuotas maxDepth="2147483647" maxStringContentLength="2147483647"
maxArrayLength="2147483647" maxBytesPerRead="2147483647"
maxNameTableCharCount="2147483647" />
</binding>
</basicHttpBinding>
</bindings>
<behaviors>
<serviceBehaviors>
<behavior name="SearchIndexServiceBehavior">
<serviceMetadata httpGetEnabled="false" />
<serviceDebug includeExceptionDetailInFaults="false" />
</behavior>
</serviceBehaviors>
</behaviors>
</system.serviceModel>
<system.transactions>
<defaultSettings timeout="00:05:00" />
</system.transactions>
</configuration>
的app.config
<configuration>
<configSections>
</configSections>
<startup>
</startup>
<system.serviceModel>
<bindings>
<basicHttpBinding>
<binding name="BasicHttpBinding_ISearchIndexServices" closeTimeout="00:00:10" openTimeout="00:00:15" receiveTimeout="00:10:00" sendTimeout="00:00:20" allowCookies="false" bypassProxyOnLocal="false" hostNameComparisonMode="StrongWildcard" maxBufferSize="5242880" maxBufferPoolSize="524288" maxReceivedMessageSize="5242880" messageEncoding="Text" textEncoding="utf-8" transferMode="Buffered" useDefaultWebProxy="true">
<readerQuotas maxDepth="32" maxStringContentLength="5242880"maxArrayLength="16384" maxBytesPerRead="4096" maxNameTableCharCount="16384" />
<security mode="None">
<transport clientCredentialType="None" proxyCredentialType="None" realm="" />
<message clientCredentialType="UserName" algorithmSuite="Default" />
</security>
</binding>
</basicHttpBinding>
</bindings>
<client>
<endpoint address="http://MyServer/SearchIndexService/SearchIndexServices.svc" binding="basicHttpBinding" bindingConfiguration="BasicHttpBinding_ISearchIndexServices" contract="WFC.ISearchIndexServices" name="BasicHttpBinding_ISearchIndexServices" />
</client>
</system.serviceModel>
</configuration>
我認為您可能正在為客戶端請求通道執行OperationTimeout,由於某種原因,通過標准配置屬性無法輕松調整它。
在調用長時間運行的操作之前,請在客戶端代碼中嘗試此操作:
((IContextChannel)clientProxy.InnerChannel).OperationTimeout = new TimeSpan(0,30,0); // For 30 minute timeout - adjust as necessary
其中clientProxy
是service-reference生成的Client類的實例(從ClientBase<ISearchIndexService>
派生)。
此服務模型示例顯示了需要在客戶端web.config中設置的綁定元素超時屬性。
請注意,所有超時屬性都設置為10分鍾。 此示例使用綁定配置元素來設置“maxItemsInObjectGraph”屬性。 通常,如果您需要關閉超時,這意味着您可能正在傳輸大量數據。 另請注意,要傳輸的數據大小都設置為最多可處理2千兆字節。
<?xml version="1.0" encoding="UTF-8"?>
<system.serviceModel>
<bindings>
<basicHttpBinding>
<binding name="BasicHttpBinding_ISearchIndexServices" closeTimeout="00:10:00" openTimeout="00:10:00" receiveTimeout="00:10:00" sendTimeout="00:10:00" allowCookies="false" bypassProxyOnLocal="false" hostNameComparisonMode="StrongWildcard" maxBufferSize="2147483647" maxBufferPoolSize="2147483647" maxReceivedMessageSize="2147483647" messageEncoding="Text" textEncoding="utf-8" transferMode="Buffered" 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>
</basicHttpBinding>
</bindings>
<client>
<endpoint address="http://MyServer/SearchIndexService/SearchIndexServices.svc" behaviorConfiguration="SearchIndexServicesBehavior" binding="basicHttpBinding" bindingConfiguration="BasicHttpBinding_ISearchIndexServices" contract="WFC.ISearchIndexServices" name="BasicHttpBinding_ISearchIndexServices" />
</client>
<behaviors>
<endpointBehaviors>
<behavior name="SearchIndexServicesBehavior">
<dataContractSerializer maxItemsInObjectGraph="2147483647" />
</behavior>
</endpointBehaviors>
</behaviors>
</system.serviceModel>
你可以試試這個
SeriveClient client=new ServiceClient();
var time = new TimeSpan(0, 3, 0);
client.Endpoint.Binding.CloseTimeout = time;
client.Endpoint.Binding.OpenTimeout = time;
client.Endpoint.Binding.ReceiveTimeout = time;
client.Endpoint.Binding.SendTimeout = time;
超時是調試的痛苦。 誰可以在一分鍾內調試! 我使用了上面的Junior M / BuzzWilder,並將以下內容添加到app.config中的服務調用中:
<binding name="WSHttpBinding_bindingname"
openTimeout="01:00:00"
closeTimeout="01:00:00"
receiveTimeout="01:00:00"
sendTimeout="01:00:00"
>
再見服務時間。 :)
超時是客戶端上的發送超時。 這是客戶端准備等待響應的時間長度,因此必須在客戶端而不是服務上設置
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.