CXF超时设置

时间:2021-12-21 23:38:43

转自:

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);

分享到: CXF超时设置 CXF超时设置
评论
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&period;apache&period;http&period;client&period;HttpClient&semi; HttpClient 4&period;3超时设置

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

  4. HttpClient 3&period;X 4&period;3 4&period;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多线程超时设置不安全&lpar;转&rpar;

    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&num; Socket连接超时设置

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

随机推荐

  1. Log4net入门使用

    简介 几乎所有的大型应用都会有自己的用于跟踪调试的API.因为一旦程序被部署以后,就不太可能再利用专门的调试工具了.然而一个管理员可能需要有一套强大的日志系统来诊断和修复配置上的问题. 经验表明,日志 ...

  2. ant常用命令

    1.ant -version

  3. 乐视云计算基于OpenStack的IaaS实践

    本文作者岳龙广,现在就职于乐视云计算有限公司,负责IaaS部门的工作. 从开始工作就混在开源世界里,在虚拟化方面做过CloudStack/Ovirt开发,现在是做以OpenStack为基础的乐视云平台 ...

  4. 如何在plSql查询数据查出的数据可编辑

    最近开发项目时要经常自己造数据,遇到好多查询出数据时要进行修改.上网查询资料 总结如下: plSql允许查询数据可以编辑的条件是必须查询出rowid 在某个表上点击query data 出现的sql语 ...

  5. ORA-12704 字符集不匹配

  6. select options常用操作

    1.判断select选项中 是否存在Value="value"的option元素 function jsSelectIsExitItem(objSelect,objItemValu ...

  7. 在自己电脑上建立SVNserver

    转载处:http://blog.csdn.net/shmily570/article/details/8227690 传统的Subversionserver配置方法: 一.准备工作 1.获取 Subv ...

  8. C&num;总结(2)

    有输出,当然有输入.这样才会有人机交互. using System; using System.Collections.Generic; using System.Linq; using System ...

  9. Java的重载和重写差别(面试常见)

    今天在看C#的基础知识,同是面向对象的语言.看到重载和重写.我突然想了半天.有点模糊了,立即度娘一番.回忆起自己在北京实习的项目,实际上,开发中经经常使用到重载和重写,自己不去总结罢了.今天找了一份比 ...

  10. glibc漏洞监测并修复

    [CVE 2015-0235: GNU glibc gethostbyname 缓冲区溢出漏洞 ]全面爆发,该漏洞的产生是Qualys公司在进行内部代码审核时,发现了一个在GNU C库(glibc)中 ...