axis设置时间范围为0-2秒

axis设置时间范围为0-2秒,第1张

来一盘地三鲜

关注

axis1.4 设置请求超时时间 原创

2014-03-23 11:03:55

来一盘地三鲜

码龄15年

关注

项目中使用axis1.4生成的webservice,访问公安网的接口,使用过程中某些业务和时间段调用接口会产生请求超时的情况,由于业务是顺序执行,无法通过线程等待一段时间的方式来处理请求超时,因此只能尝试从webservice自身入手。

先说解决方案:通过各种设置setTimeout来控制请求超时时间。

具体怎么设置,尝试过的有如下几种:

如果是使用stub方式调用webservice,有两种方式设定:

1:统一所有出口的超时时间设定:

这种方式在axis生成的四个客户端类中,对stub这个类下手,这个类就是stub方式调用的核心类,以前总认为它是自动生成能的,不能随便乱动,其实不然,关键是找到下手的地方。仔细阅读,你会在这个类里面找到webservice服务端对外暴露的方法,然后在在该方法里面找到生成call对象的地方,加入如下一行代码即可:

_call.setTimeOut(30000) //单位是毫秒

如果你想更灵活的控制超时时间,不妨把控制时间设置到配置文件里。

2:单个方法的超时时间控制:

在你的业务类处理接口调用方法里面,在获得stub对象的下面,加入如下代码:

stub.setTimeOut(30000) //单位是毫秒

这种方案控制到了具体的某个方法,更灵活。

解决方案来自于这里:

http://axis.apache.org/axis/faq.html#faq17

如果你是使用便捷模式调用,那更简单,直接一句话(标红代码):

String endpoint="http://ip/project/services/xxx?wsdl"

Service service =new service()

Call call=(Call) service.createCall()

call.setTargetEndpointAddress(endpoint)

call.setOperationName("methodname")

call.setTimeout(10000) //单位是毫秒

String ret =(String)call.invoke(new Object[] {xmldoc})

这种方法简单便捷,对于测试webservice极为方便,但是缺少灵活性,工程一般不建议使用。

最重要的,所有的方案都是从客户端下手,因为服务端常常不是你所能控制的。

总结:

1:要保持英文阅读的能力,不然就算有解决方案都看不懂。

2:不要人云亦云:其实long long ago,在网上就查到过通过设置setTimeout参数来控制超时时间的观点,但是好多人都说这个参数设置无效,当时也没有深入,只是人云亦云的想当然,大多数人的悲哀,挣扎吧,少年。

3:经验是一个不断积累的过程,也只有经验积累到了一定程度,娴熟了,才会有庖丁解牛的勇气和行动。

应该可以的,setTimeOutInMilliSeconds是设毫秒的喔,你尝试一下再改短一点。setTimeOutInMilliSeconds(100L)。

org.apache.commons.httpclient.ConnectTimeoutException: The host did not accept the connection within timeout of 100 ms

at org.apache.commons.httpclient.protocol.ReflectionSocketFactory.createSocket(ReflectionSocketFactory.java:155)

at org.apache.commons.httpclient.protocol.DefaultProtocolSocketFactory.createSocket(DefaultProtocolSocketFactory.java:125)

at org.apache.commons.httpclient.HttpConnection.open(HttpConnection.java:707)

at org.apache.commons.httpclient.MultiThreadedHttpConnectionManager$HttpConnectionAdapter.open(MultiThreadedHttpConnectionManager.java:1361)

at org.apache.commons.httpclient.HttpMethodDirector.executeWithRetry(HttpMethodDirector.java:387)

at org.apache.commons.httpclient.HttpMethodDirector.executeMethod(HttpMethodDirector.java:171)

at org.apache.commons.httpclient.HttpClient.executeMethod(HttpClient.java:397)

at org.apache.commons.httpclient.HttpClient.executeMethod(HttpClient.java:346)


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/tougao/11051615.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-13
下一篇 2023-05-13

发表评论

登录后才能评论

评论列表(0条)

保存