.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。 |
子元素
元素 | 说明 |
---|---|
提供一组正则表达式来描述不使用代理的地址。 |
|
向应用程序添加新的代理模块。 |
|
定义代理服务器。 |
父元素
元素 | 说明 |
---|---|
包含指定 .NET Framework 与网络的连接方式的设置。 |
据我的理解,由于web代理默认是开启的,也就是HttpWebRequest.DefaultWebProxy的值不为null,而这个DefaultWebProxy是一个全局变量。故第一次调用webservice方法的时候只有等这个默认代理超时以后才能绕过,所以第一次比较慢。