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

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

  • 相关阅读:
    jmeter4-数据库性能测试
    jmeter2-接口性能测试
    jmeter1-测试流程
    jmeter-beanshell随机取数组一项
    最强MySQL数据库设计规范... (转载)
    Python词云
    adb常用命令
    jmeter线程组多个请求之间的参数关联
    VisualVM使用与调优案例
    mysql调优工具tuning-primer.sh的使用
  • 原文地址:https://www.cnblogs.com/xienb/p/3318199.html
Copyright © 2020-2023  润新知