Wcf 第一次调用Dynamics GP 2010 Web Services需要10+;秒

Wcf 第一次调用Dynamics GP 2010 Web Services需要10+;秒,wcf,web-services,dynamics-gp,Wcf,Web Services,Dynamics Gp,我有一个与.NET 4 WCF web服务通信的网站。该WCF服务连接到远程服务器上的Dynamics GP Web服务。这两个Web服务都是自托管的(没有IIS) 第一次呼叫GP大约需要12秒才能完成!!之后立即拨打的电话(即使是在另一个WCF请求中)约为100毫秒,但如果我在两次呼叫之间等待一分钟或两分钟,将再次需要10秒 问题的原因可能是什么,如何解决 我已经使用SvcUtil和VS2010 Add Service引用生成了一个代理,但两者都有相同的问题。动态GP代理文件是巨大的3MB,不

我有一个与.NET 4 WCF web服务通信的网站。该WCF服务连接到远程服务器上的Dynamics GP Web服务。这两个Web服务都是自托管的(没有IIS)

第一次呼叫GP大约需要12秒才能完成!!之后立即拨打的电话(即使是在另一个WCF请求中)约为100毫秒,但如果我在两次呼叫之间等待一分钟或两分钟,将再次需要10秒

问题的原因可能是什么,如何解决

我已经使用SvcUtil和VS2010 Add Service引用生成了一个代理,但两者都有相同的问题。动态GP代理文件是巨大的3MB,不知道这是否相关

我运行Wireshark分析网络流量,实际的tcp请求-应答流似乎只需不到一秒钟的时间。在发送请求之前似乎发生了一些事情,占用了10秒的时间

以下是使用的代码:

Context context = new Context();
CompanyKey companyKey = new CompanyKey();
companyKey.Id = -1;
context.OrganizationKey = companyKey;

System.Diagnostics.Stopwatch sw = new System.Diagnostics.Stopwatch();
sw.Start();

_proxy = new DynamicsGPClient();
_proxy.ClientCredentials.Windows.ClientCredential.Domain = Domain;
_proxy.ClientCredentials.Windows.ClientCredential.UserName = Username;
_proxy.ClientCredentials.Windows.ClientCredential.Password = Password;

long openingMs = sw.ElapsedMilliseconds;
CustomerCriteria customerCriteria = new CustomerCriteria();
CustomerSummary[] gpCustomers = _proxy.GetCustomerList(customerCriteria, context);
long fctCallMs = sw.ElapsedMilliseconds;
...
if (_proxy != null && _proxy.State != System.ServiceModel.CommunicationState.Faulted) {
    _proxy.Close();
}
以下是app.config:

<system.serviceModel>
   <bindings>
      <wsHttpBinding>
         <binding name="GPWebService" closeTimeout="00:01:00" openTimeout="00:01:00"
                  receiveTimeout="00:10:00" sendTimeout="00:01:00" bypassProxyOnLocal="false" 
                  transactionFlow="false" hostNameComparisonMode="StrongWildcard" 
                  maxBufferPoolSize="2147483647" maxReceivedMessageSize="2147483647" 
                  messageEncoding="Text" textEncoding="utf-8" 
                  useDefaultWebProxy="true" allowCookies="false">
            <readerQuotas maxDepth="32" maxStringContentLength="8192" maxArrayLength="16384" 
                          maxBytesPerRead="4096" maxNameTableCharCount="2147483647"/>
            <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"/>
            </security>
         </binding>
      </wsHttpBinding>
   </bindings>
   <client>
      <endpoint address="http://192.168.x.y:48620/Dynamics/GPService/GPService" binding="wsHttpBinding"
                bindingConfiguration="GPWebService"
                contract="DynamicsGpService.DynamicsGP" name="GPWebService">
         <identity>
            <userPrincipalName value="DEV\gpeconnect"/>
         </identity>
      </endpoint>
   </client>
</system.serviceModel>

自我回答

对于社区来说,以下是我发现的(但我无法解释原因,所以不要问!)

在客户端的app.config中,
useDefaultWebProxy=“true”
应设置为
false
。。。这使得一个非常简单的Hello World Web服务在第一次呼叫时从7秒传递到100毫秒


在客户端的app.config中,完全删除
identity>userPrincipalName
部分导致第一个WCF调用从>10秒传递到~1秒

我对Dynamics一无所知,但这听起来像是托管Dynamics服务的IIS应用程序池首次启动。这可能需要一些时间。假设是这种情况,您可能需要检查应用程序池上的超时设置。IIS应用程序池的默认超时时间为20分钟,因此增加该时间可以减少您必须经历此启动延迟的次数。谢谢Chris,但我不这么认为,Web服务(Dynamics和我自己的)都是“自托管”的。而且,它远远低于20分钟的标志,长时间延迟回来。。。