2009-09-08 98 views
0

全部,WCF间歇性超时

我有一个WCF服务,间歇地超时,通常在约10或12个来自asp.net客户端的请求之后。该服务使用反射来查找其程序集(WAP dll)中具有自定义属性集的类。这个过程本身非常快,通常只需要几毫秒,当它工作时,效果很好。

在调用代码和服务本身中设置断点告诉我,WCF客户端代理类的调用和实际执行该方法的时间之间发生超时。

想法?

更新:结合等从web.config中:

<system.serviceModel> 
    <behaviors> 
     <serviceBehaviors> 
     <behavior name="Sdd.Services.ControlPanelBehavior"> 
      <serviceMetadata httpGetEnabled="true" /> 
      <serviceDebug includeExceptionDetailInFaults="false" /> 
     </behavior> 
     </serviceBehaviors> 
    </behaviors> 
    <services> 
     <service behaviorConfiguration="Sdd.Services.ControlPanelBehavior" 
     name="Sdd.Services.ControlPanel"> 
     <endpoint address="" binding="wsHttpBinding" contract="Sdd.Services.IControlPanel"> 
      <identity> 
      <dns value="localhost" /> 
      </identity> 
     </endpoint> 
     <endpoint address="mex" binding="mexHttpBinding" contract="IMetadataExchange" /> 
     </service> 
    </services> 
    </system.serviceModel> 

更新:下面是从客户端的web.config中的相关部分:

<system.serviceModel> 
    <bindings> 
    <wsHttpBinding> 
    <binding name="WSHttpBinding_IControlPanel" closeTimeout="00:01:00" 
    openTimeout="00:01:00" receiveTimeout="00:10:00" sendTimeout="00:01:00" 
    bypassProxyOnLocal="false" transactionFlow="false" hostNameComparisonMode="StrongWildcard" 
    maxBufferPoolSize="524288" maxReceivedMessageSize="65536" messageEncoding="Text" 
    textEncoding="utf-8" useDefaultWebProxy="true" allowCookies="false"> 
    <readerQuotas maxDepth="32" maxStringContentLength="8192" maxArrayLength="16384" 
     maxBytesPerRead="4096" maxNameTableCharCount="16384" /> 
    <reliableSession ordered="true" inactivityTimeout="00:10:00" 
     enabled="false" /> 
    <security mode="Message"> 
     <transport clientCredentialType="Windows" proxyCredentialType="None" 
     realm="" /> 
     <message clientCredentialType="Windows" negotiateServiceCredential="true" 
     algorithmSuite="Default" establishSecurityContext="true" /> 
    </security> 
    </binding> 
    </wsHttpBinding> 
    </bindings> 
    <client> 
    <endpoint address="http://localhost:81/services/ControlPanel.svc" 
    binding="wsHttpBinding" bindingConfiguration="WSHttpBinding_IControlPanel" 
    contract="PublicSite.IControlPanel" name="WSHttpBinding_IControlPanel"> 
    <identity> 
    <dns value="localhost" /> 
    </identity> 
    </endpoint> 
    </client> 
</system.serviceModel> 
+0

你有更多的信息吗?您使用的是什么类型的配置(绑定,客户端和服务器位于何处,设置的不同超时值是多少)。当你增加超时会发生什么? – olle 2009-09-08 23:24:52

+0

客户端和服务器都在我的开发箱上,在UltiDev Cassini下运行。当它工作时,响应时间低于50ms。这是一致的,直到它突然*不*工作,当它在几分钟后超时。 我不确定绑定是什么 - 我采取了天真的方法右键单击,添加... VS2008中的WCF服务。如果您能指出我在哪里可以找到这些信息,我很乐意回报。谢谢! – 2009-09-09 00:01:09

+0

我知道它正在攻击症状,但请检查一下您的绑定超时设置。有关解释,请参见http://msdn.microsoft.com/en-us/library/ms731291.aspx。 – 2009-09-09 00:01:50

回答

4

哎呀!

这可能是最愚蠢的错误,但我想出了问题:因为我习惯于使用web引用(.asmx web服务)而不是服务引用(WCF),所以我忽略了关闭代理对象。改变

[WebMethod] 
    public static List<Page>PagesGetAll() 
    { 
     ControlPanelClient cp = new ControlPanelClient(); 
     Page[] pageArray = cp.NavigationPagesGetAll(); 
     List<Page> pageList = pageArray.ToList<Page>(); 

     // make sure that the page list in the database is up-to-date. 
     foreach(Page page in pageList) 
      Navigation.PageUpdate(page); 

     return pageList; 
    } 

public static List<Page>PagesGetAll() 
    { 
     List<Page> pageList = null; 

     using (ControlPanelClient cp = new ControlPanelClient()) 
     { 
      Page[] pageArray = cp.NavigationPagesGetAll(); 
      pageList = pageArray.ToList<Page>(); 
      // implied cp.Close() from "using" statement 
     } 

     // make sure that the page list in the database is up-to-date. 
     foreach(Page page in pageList) 
      Navigation.PageUpdate(page); 

     return pageList; 
    } 

而问题就消失了。在验证这个解决方案之后,我还增加了并发请求的数量,因为具有超过10-12个并发请求会产生我之前看到的同样的问题似乎是合乎逻辑的。

谢谢大家!

+0

大声笑,我在看到答案之前在代理的中止/关闭时添加了对以上问题的评论(错误排序的答案):D – 2009-10-14 14:06:50

0

不幸的是,config中最重要的部分(绑定和服务端点)缺失 - 客户端配置也是如此。

但是你描述它的方式,这10-12个请求似乎工作正常,然后出现故障,可能指向服务器上的并发/限制问题。

我会尝试增加并发呼叫和会话的数量,以查看是否有帮助。要做到这一点,你需要一个serviceThrottling部分添加到您的行为的配置在服务器上:

<behavior name="Sdd.Services.ControlPanelBehavior"> 
    <serviceMetadata httpGetEnabled="true" /> 
    <serviceDebug includeExceptionDetailInFaults="false" /> 
    <serviceThrottling 
     maxConcurrentCalls="25"   // default is 16 
     maxConcurrentSessions="25"  // default is 10 
     maxConcurrentInstances="25" /> // no default 
</behavior> 

是否有帮助 - 你有一个问题与会话太多或者被打开并发呼叫。 wsHttpBinding协议默认会使用会话,所以也许你只需要告诉它使用per-call就可以了。

Marc