• WebService超时的解决办法


    Winform客户端调用Webservice 120秒超时.对此问题,针对服务器与客户端分别作了超时设置为300S.
    1. 服务器端设置超时
    在 web.config 的 system.web 里添加如下配置项:
      < httpRuntime
    executionTimeout="300000"
    />
    以上时间单位是秒.
    记得要把 web.config 的 debug 模式关闭:
      < compilation  
    defaultLanguage="c#"
    debug="false"
    />
    2. 客户端设置超时
    在 WebService 的客户端代理程序(用 wsdl.exe 生成)里设置 Request 超时时间, 单位是毫秒:
    protected override WebRequest GetWebRequest(Uri uri)
    {
    HttpWebRequest wr = (HttpWebRequest)base.GetWebRequest( uri );
    wr.Timeout = 300*1000;
    return wr;
    }
    但还是会出现120S超时.
    此问题可以得出以下结论:
                    1:可能是服务器的问题
                    2:可能是客户端.net环境配置的问题
                    3:可能是网域的问题
                    4:可能是网路的问题
    对此.分别作如下测试:
                    1:更换客户端电脑.测试有些电脑出现超时,有些电脑不会超时.可以肯定.服务器是没有问题
                    2:分别查看几台客户端电脑配置,以没有发现问题.
                    3:在同一个网域里面,有的电脑不会超时,有些电脑超时.所以,可以排除网域问题.
                    4:对于网路的问题,有分别查看各网段路由设置.但没有发现问题.
    以上的测试,好象都可以排除.难不成是MS的Bug.在网上查了一通,根本没有本到什么结果.现在,回头想一想webservice原理:
    客户端和服务端把请求和数据结果以XML的形式进行SOAP包装,以HTTP等形式进行传送,从而实现相应交互
    根据Webservice原理,可以肯定是Http超时.那么问题到底出现在哪里,路由器设置没有问题,网路也通顺.会不会是IE版本 问题.问题越来越接近.最后查看半天,没有发现问题,偶然点了一下IE的代理设置 .发现有设置代理.难不成是代理引发超时.经过最后测试.发现问题的根本原因就是代理设置超时时间120S.
    总结一下:
          webservice超时问题,先应该从程式上着手.比如:web.config超时设置, 以及客户端的超时设置 .如果设置后还是发生超时.那就得从webservice运行原理上去找原因.也就是从http上找原因:比如:网路问题 ,IE代理设置问题, 以及其它对网路设置引发超时的问题

  • 相关阅读:
    整理sql server数据类型
    【MVC4升级到MVC5】ASP.Net MVC 4项目升级MVC 5的方法
    MVC学习笔记:入门
    maven第一次创建项目太慢解决方法
    idea中创建maven的Javaweb工程并进行配置
    idea中MavenWeb项目不能创建Servlet的解决办法
    Java模拟客户端向服务器上传文件
    Java学习随笔---常用API(二)
    ssh设置超时时间
    linux 登陆失败处理
  • 原文地址:https://www.cnblogs.com/kk1230/p/1946218.html
Copyright © 2020-2023  润新知