• 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方法的时候只有等这个默认代理超时以后才能绕过,所以第一次比较慢。

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

  • 相关阅读:
    程序集、属性和元数据
    wget 使用探索
    为wget使用代理
    创建项目 (Visual C#)
    wget 下载整个网站,或者特定目录
    演练:使用 Visual C# 创作用户控件
    NavigateUrl属性绑定 天高地厚
    【转载】Repeater控件里的大智慧 天高地厚
    【转载】ASP.NET Page 那点事 天高地厚
    意向锁如何提高性能 天高地厚
  • 原文地址:https://www.cnblogs.com/xienb/p/3318199.html
Copyright © 2020-2023  润新知