.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。 |
子元素
父元素
据我的理解,由于web代理默认是开启的,也就是HttpWebRequest.DefaultWebProxy的值不为null,而这个DefaultWebProxy是一个全局变量。故第一次调用webservice方法的时候只有等这个默认代理超时以后才能绕过,所以第一次比较慢。
更多介绍请参考这里,还有这里
|