转自:

http://peak.iteye.com/blog/1285211

http://win.sy.blog.163.com/blog/static/94197186201310143856448/

http://blog.csdn.net/pengchua/article/details/5081178

主要在客户端调用时设置 :

  1. 在使用WebService的时候,我们可能需要一个备份的WebService服务器.一旦主服务器down了,我们可以使用备份的服务器.那么这里就需要对客服端连接服务器的时间做一个修改.
  2. 在Spring+CXF的WebService环境下,客户端有两个时间属性是可配置的,分别是ConnectionTimeout和ReceiveTimeout.
  3. ConnectionTimeout--WebService以TCP连接为基础,这个属性可以理解为tcp的握手时的时间设置,超过设置的时间长则认为是连接超时.以毫秒为单位,默认是30000毫秒,即30秒.
  4. ReceiveTimeout -- 这个属性是发送WebService的请求后等待响应的时间,超过设置的时长就认为是响应超时.以毫秒为单位,默认是60000毫秒,即60秒.
  5. beans.xml 设置的例子:
  6. <?xml version="1.0" encoding="UTF-8"?>
  7. <beans xmlns="http://www.springframework.org/schema/beans"
  8. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  9. xmlns:jee="http://www.springframework.org/schema/jee"
  10. xmlns:jaxws="http://cxf.apache.org/jaxws"
  11. xmlns:http-conf="http://cxf.apache.org/transports/http/configuration"
  12. xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.0.xsd
  13. http://www.springframework.org/schema/jee http://www.springframework.org/schema/jee/spring-jee-2.0.xsd
  14. http://cxf.apache.org/jaxws http://cxf.apache.org/schemas/jaxws.xsd
  15. http://cxf.apache.org/transports/http/configuration http://cxf.apache.org/schemas/configuration/http-conf.xsd ">
  16. <http-conf:conduit name="{http://impl.service.product.super.com/}ProjectService.http-conduit">
  17. <http-conf:client ConnectionTimeout="10000" ReceiveTimeout="20000"/>
  18. </http-conf:conduit>
  19. </beans>
  20. 这里需要注意的有几个地方:
  21. 1:需要指定http-conf名称空间 xmlns:http-conf=http://cxf.apache.org/transports/http/configuration
  22. 2:指定模式位置: http://cxf.apache.org/transports/http/configuration http://cxf.apache.org/schemas/configuration/http-conf.xsd
  23. 3:http-conf:conduit中的name属性,指定设置生效的服务,如例子中,只对服务名为{http://impl.service.product.sww.com/}ProjectService的服务生效.
  24. 使用下面的设置则会对所有服务生效
  25. <http-conf:conduit name="*.http-conduit">
  26. <http-conf:client……>
  27. </http-conf:conduit>
  28. 更详细的配置请参考CXF官方文档:
  29. http://cwiki.apache.org/CXF20DOC/client-http-transport-including-ssl-support.html

`2.代码编写:

private static void recieveTimeOutWrapper(Object o)

{

Conduit conduit = (ClientProxy.getClient(o).getConduit());

HTTPConduit hc = (HTTPConduit)conduit;

HTTPClientPolicy client = new HTTPClientPolicy();

client.setReceiveTimeout(1000 * 60 * 5); // 5分钟超时时间。 该时间为响应超时。

// client.setConnectionTimeout(1000 * 45); // 45秒的连接超时。

hc.setClient(client);

}

recieveTimeOutWrapper(o)  包装每一个服务

使用WebService时,我们通常都会在客户端中设置请求超时的限制,以避免长时间的去连接不可用的服务器。在CXF的环境下,客户端可通过两个属性配置超时限制:

  • ConnectionTimeout - WebService以TCP连接为基础,这个属性可以理解为TCP握手时的时间设置,超过设置的时间就认为是连接超时.以毫秒为单位,默认是30000毫秒,即30秒。
  • ReceiveTimeout - 这个属性是发送WebService的请求后等待响应的时间,超过设置的时长就认为是响应超时.以毫秒为单位,默认是60000毫秒,即60秒.
  1. Client client = ClientProxy.getClient(port);
  2. HTTPConduit http = (HTTPConduit) client.getConduit();
  3. HTTPClientPolicy httpClientPolicy = new HTTPClientPolicy();
  4. httpClientPolicy.setConnectionTimeout(36000);
  5. httpClientPolicy.setAllowChunking(false);
  6. httpClientPolicy.setReceiveTimeout(32000);
  7. http.setClient(httpClientPolicy);

spring+cxf配置方式:

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <beans xmlns="http://www.springframework.org/schema/beans"
  3. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  4. xmlns:jee="http://www.springframework.org/schema/jee"
  5. xmlns:jaxws="http://cxf.apache.org/jaxws"
  6. xmlns:http-conf="http://cxf.apache.org/transports/http/configuration"
  7. xsi:schemaLocation="http://www.springframework.org/schema/beans
  8. http://www.springframework.org/schema/beans/spring-beans-2.0.xsd
  9. http://www.springframework.org/schema/jee
  10. http://www.springframework.org/schema/jee/spring-jee-2.0.xsd
  11. http://cxf.apache.org/jaxws http://cxf.apache.org/schemas/jaxws.xsd
  12. http://cxf.apache.org/transports/http/configuration
  13. http://cxf.apache.org/schemas/configuration/http-conf.xsd ">
  14. <http-conf:conduit name="{WSDL Namespace}portName.http-conduit">
  15. <http-conf:client ConnectionTimeout="10000" ReceiveTimeout="20000"/>
  16. </http-conf:conduit>
  17. </beans>

这里需要注意的有几个地方:  
   1、需要指定http-conf名称空间:xmlns:http-conf=http://cxf.apache.org/transports/http/configuration。
   2、指定模式位置: http://cxf.apache.org/transports/http/configuration http://cxf.apache.org/schemas/configuration/http-conf.xsd。
   3、http-conf:conduit中的name属性,指定设置生效的服务。name属性由service的namespace、WSDL中的 port name和".http-conduit"组成,如{http://apache.org/hello_world}HelloWorld.http- conduit。如果将name属性设置为“*.http-conduit”,则会对所有服务生效。

另外,WSDL中的endpoint的地址不一定是有效的,为避免客户端请求使用该地址,我们在请求前应通过以下方式强行设置为可用的服务地址。
  ((BindingProvider) port).getRequestContext().put(BindingProvider.ENDPOINT_ADDRESS_PROPERTY,serviceUrl);

分享到:  
评论
2 楼 peak 2012-03-30  
tangduDream 写道
我想问你一个问题,为什么我配置:
//超时设置
Client clientP = ClientProxy.getClient(companyService);
HTTPConduit http = (HTTPConduit) clientP.getConduit();
HTTPClientPolicy httpClientPolicy = new HTTPClientPolicy();
        //httpClientPolicy.setConnectionTimeout(20000);
        httpClientPolicy.setReceiveTimeout(5*60*1000);
        //httpClientPolicy.setAllowChunking(false);
        http.setClient(httpClientPolicy);
我设置了5分钟 ,可是服务端却在5分钟内还在运行,直到超时?

这是为什么呢?

我也不知道,我设置了之后感觉也没啥反映,所以我都改用httpclient做了,报文封装自己做

1 楼 tangduDream 2012-01-18  
我想问你一个问题,为什么我配置:
//超时设置
Client clientP = ClientProxy.getClient(companyService);
HTTPConduit http = (HTTPConduit) clientP.getConduit();
HTTPClientPolicy httpClientPolicy = new HTTPClientPolicy();
        //httpClientPolicy.setConnectionTimeout(20000);
        httpClientPolicy.setReceiveTimeout(5*60*1000);
        //httpClientPolicy.setAllowChunking(false);
        http.setClient(httpClientPolicy);
我设置了5分钟 ,可是服务端却在5分钟内还在运行,直到超时?

这是为什么呢?

CXF超时设置的更多相关文章

  1. delphi tidhttp 超时设置无效的解决方法

    现在delphi都发布到xe8了,tidhttp还有缺陷,那就是超时设置在没有网络或者连不上服务器的时候是无效的,不管你设置为多少都要10-20秒.connectTimeout和readTimeout ...

  2. Linux串口中的超时设置

    在Linux下使用串口通信时,默认的阻塞模式是不实用的.而采用select或epoll机制的非阻塞模式,写代码有比较麻烦.幸好Linux的串口自己就带有超时机制. Linux下使用termios.h中 ...

  3. org.apache.http.client.HttpClient; HttpClient 4.3超时设置

    可用的code import org.apache.commons.lang.StringUtils;import org.apache.http.HttpEntity;import org.apac ...

  4. HttpClient 3.X 4.3 4.x超时设置

    HttpClient 4.3.HttpClient这货和Lucene一样,每个版本的API都变化很大,这有点让人头疼.就好比创建一个HttpClient对象吧,每一个版本的都不一样, 3.X是这样的 ...

  5. Apache性能优化、超时设置,linux 重启apache

    在httpd.conf中去掉Include conf/extra/httpd-default.conf前的#以使httpd-default.php生效.其中调节以下参数Timeout 15 (连接超时 ...

  6. libcurl多线程超时设置不安全(转)

    from http://www.cnblogs.com/kex1n/p/4135263.html (1), 超时(timeout) libcurl 是 一个很不错的库,支持http,ftp等很多的协议 ...

  7. 使用select io复用实现超时设置

    在linux的socket编程中,经常会遇到超时设置的问题,例如请求方如果在Ks内不发送数据则服务器要断开连接停止服务.这里我使用select的io复用实现超时5s设置,具体代码片段如下: fd_se ...

  8. jquery ajax超时设置

    var ajaxTimeoutTest = $.ajax({ url:'',  //请求的URL timeout : 1000, //超时时间设置,单位毫秒 type : 'get',  //请求方式 ...

  9. C# Socket连接超时设置

    问题描述:         对于C# Socket没有超时设置的选项,默认情况下进行Socket连接,返回连接失败需要20-30s时间,严重影响用户体验 问题解决: Socket服务器端: Socke ...

随机推荐

  1. meta 标签 关键字 用处

    您的个人网站即使做得再精彩,在“浩瀚如海”的网络空间中,也如一叶扁舟不易为人发现,如何推广个人网站, 人们首先想到的方法无外乎以下几种: l 在搜索引擎中登录自己的个人网站 l 在知名网站加入你个人网 ...

  2. HDU 5692 线段树+dfs序

    Snacks Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)Total Sub ...

  3. leetcode 147. Insertion Sort List ----- java

    Sort a linked list using insertion sort. 插入排序. /** * Definition for singly-linked list. * public cla ...

  4. leetcode 95 Unique Binary Search Trees II ----- java

    Given an integer n, generate all structurally unique BST's (binary search trees) that store values 1 ...

  5. Docker安装及基本使用方法

    Docker安装 CentOS6上安装Docker # yum -y install epel-release # yum -y install docker-io CentOS7上安装Docker ...

  6. timus 1982 Electrification Plan(最小生成树)

    Electrification Plan Time limit: 0.5 secondMemory limit: 64 MB Some country has n cities. The govern ...

  7. 团队项目开发中,常见的版本控制有svn,git

    团队项目开发中,常见的版本控制有svn,git

  8. jQuery对下拉框Select操作总结

    jQuery对下拉框Select操作总结 转自网络,留做备用 jQuery获取Select元素,并选择的Text和Value: 1. $("#select_id").change( ...

  9. Optimize Managed Code For Multi-Core Machines

    Parallel Performance Optimize Managed Code For Multi-Core Machines Daan Leijen and Judd Hall This ar ...

  10. python命令行添加Tab键自动补全

    1.编写一个tab的自动补全脚本,名为tab.py #!/usr/bin/python # python tab complete import sys import readline import ...