winform客户端程序第一次调用webservice方法很慢的解决方法

  .net2.0的winform客户端最常用的与服务端通信方式是通过webservice,最近在用dottrace对客户端做性能测试的时候发现,客户端程序启动以后,第一次调用某一个webservice的方法是,总是特别慢,大概需要0.8-1秒钟的时间,而接下来掉其他方法就很快了,都只需要几十毫秒。google了一把,找到解决办法:

  在应用程序的config文件中加入以下配置节:

<system.net>
    <defaultProxy enabled="false" useDefaultCredentials="false">
      <proxy/>
      <bypasslist/>
      <module/>
    </defaultProxy>
  </system.net>

或者在程序入口加入以下代码:

HttpWebRequest.DefaultWebProxy = null;

  msdn上的解释:

属性

 
元素 说明

enabled

指定是否使用 Web 代理。默认值为 true

useDefaultCredentials

指定是否使用此主机的默认凭据访问 Web 代理。默认值为 false

子元素

 
元素 说明

bypasslist

提供一组正则表达式来描述不使用代理的地址。

module

向应用程序添加新的代理模块。

proxy

定义代理服务器。

父元素

 
元素 说明

system.net

包含指定 .NET Framework 与网络的连接方式的设置。

  据我的理解,由于web代理默认是开启的,也就是HttpWebRequest.DefaultWebProxy的值不为null,而这个DefaultWebProxy是一个全局变量。故第一次调用webservice方法的时候只有等这个默认代理超时以后才能绕过,所以第一次比较慢。

  更多介绍请参考这里,还有这里

你可能感兴趣的:(webservice)