带有JDK 8的AXIS Client 1.4提供了org.apache.axis.AxisFault:java.util.ConcurrentModificationException

时间:2018-09-07 08:46:07

标签: java soap java-8 axis

我正在使用AXIS(1.4)客户端来调用SOAP Web服务,而JDK版本是8。在某些SOAP服务调用中出现间歇性错误。在负载情况下,对于1000个请求中的5-10个,就会发生这种情况。

Caused by: org.apache.axis.AxisFault: java.util.ConcurrentModificationException
at org.apache.axis.message.SOAPFaultBuilder.createFault(SOAPFaultBuilder.java:223) ~[axis-1.4.jar:na]
at org.apache.axis.message.SOAPFaultBuilder.endElement(SOAPFaultBuilder.java:130) ~[axis-1.4.jar:na]
at org.apache.axis.encoding.DeserializationContext.endElement(DeserializationContext.java:1104) ~[axis-1.4.jar:na]
at org.apache.xerces.parsers.AbstractSAXParser.endElement(Unknown Source) ~[na:na]
at org.apache.xerces.impl.XMLNSDocumentScannerImpl.scanEndElement(Unknown Source) ~[na:na]
at org.apache.xerces.impl.XMLDocumentFragmentScannerImpl$FragmentContentDispatcher.dispatch(Unknown Source) ~[na:na]
at org.apache.xerces.impl.XMLDocumentFragmentScannerImpl.scanDocument(Unknown Source) ~[na:na]
at org.apache.xerces.parsers.XML11Configuration.parse(Unknown Source) ~[na:na]
at org.apache.xerces.parsers.XML11Configuration.parse(Unknown Source) ~[na:na]
at org.apache.xerces.parsers.XMLParser.parse(Unknown Source) ~[na:na]
at org.apache.xerces.parsers.AbstractSAXParser.parse(Unknown Source) ~[na:na]
at org.apache.xerces.jaxp.SAXParserImpl$JAXPSAXParser.parse(Unknown Source) ~[na:na]
at org.apache.axis.encoding.DeserializationContext.parse(DeserializationContext.java:241) ~[axis-1.4.jar:na]
at org.apache.axis.SOAPPart.getAsSOAPEnvelope(SOAPPart.java:696) ~[axis-1.4.jar:na]
at org.apache.axis.Message.getSOAPEnvelope(Message.java:435) ~[axis-1.4.jar:na]
at org.apache.axis.handlers.soap.MustUnderstandChecker.invoke(MustUnderstandChecker.java:62) ~[axis-1.4.jar:na]
at org.apache.axis.client.AxisClient.invoke(AxisClient.java:206) ~[axis-1.4.jar:na]
at org.apache.axis.client.Call.invokeEngine(Call.java:2782) ~[axis-1.4.jar:na]
at org.apache.axis.client.Call.invoke(Call.java:2765) ~[axis-1.4.jar:na]
at org.apache.axis.client.Call.invoke(Call.java:2443) ~[axis-1.4.jar:na]
at org.apache.axis.client.Call.invoke(Call.java:2366) ~[axis-1.4.jar:na]
at org.apache.axis.client.Call.invoke(Call.java:1812) ~[axis-1.4.jar:na]
at com.te.prodirectory.services.client.PaymentWSSoapBindingStub.validateVamPayment(PaymentWSSoapBindingStub.java:423) ~[directory-qe-client-3.2.0-VAM2-RC24.jar:3.2.0-VAM2-RC24]
at com.te.prodirectory.services.payment.PaymentServiceWsImpl.validateVamPayment(PaymentServiceWsImpl.java:34) ~[directory-qe-client-3.2.0-VAM2-RC24.jar:3.2.0-VAM2-RC24]
... 37 common frames omitted

注意:当我们将相同的AXIS客户端与JDK 7一起使用时,根本不会遇到此问题。

我尝试用JDK 8搜索类似的AXIS问题,但存在一些兼容性问题,但与我当前面临的问题完全不同。

3 个答案:

答案 0 :(得分:2)

同意https://issues.apache.org/jira/browse/AXIS-2909似乎是问题所在。 通常无法选择返回到jdk7。

AXIS-2909的建议是采用最新的1.4.1-SNAPSHOT,该文件来自于2017年成功的詹金斯构建。它来自http://svn.apache.org/repos/asf/axis/axis1/java/trunk,并且简而言之,此主干进行了很多更改自2006年(1.4)起,尚未正式发布。  -增加了Maven支持  -完全重组为Maven模块  -许多不同的更改,请查看svn日志

维森(A. Veithen)在这根树干上做得很好,而且似乎是维护者。

一种更好的方法和一种更安全的方法是,您只想修复轴ConcurrentModificationException错误,并且不进行超出所需的更多更改,可以采用1.4标记,然后在其之上应用补丁。

https://svn.apache.org/repos/asf/axis/axis1/java/tags/1.4/

补丁:

   // Convert to array before sorting to avoid concurrency issues
    OperationDesc[] array = (OperationDesc[])overloads.toArray(
        new OperationDesc[overloads.size()]);


    Arrays.sort(array,
        new Comparator() {
            public int compare(Object o1, Object o2)
            {
                Method meth1 = ((OperationDesc)o1).getMethod();
                Method meth2 = ((OperationDesc)o2).getMethod();
                return (meth1.getParameterTypes().length -
                                     meth2.getParameterTypes().length);
            }
        });

    return array;
}

btw:还需要AXIS-2875,以使其与java8一起编译。

请注意,这将是一次时间机器体验,因为您回到了ant build-script时代。 您还需要将j2ee-1.4.jar包含为编译时库。 但随后您就可以使用了,可以烘烤您自己的1.4.1 1.4 + AXIS-2909

答案 1 :(得分:1)

我遵循了这种快速而肮脏的方式,使用javac 1.8修补axis-1.4.jar:

  1. 从maven存储库https://mvnrepository.com/artifact/org.apache.axis/axis/1.4下载axis-1.4.jar

也从maven axis-jaxrpc-1.4.jar和commons-logging-1.1.1.jar下载

  1. 从原始源代码复制JavaServiceDesc.java,以导出它们,我使用过:

svn导出https://svn.apache.org/repos/asf/axis/axis1/java/tags/1.4轴1.4

  1. 按照geewee的建议,在JavaServiceDesc.java中的第527行编辑getOperationsByQName的最后几行

  2. 使用Java 8进行编译:

    javac -d。 -classpath axis-1.4.jar; axis-jaxrpc-1.4.jar; commons-logging-1.1.1.jar JavaServiceDesc.java

  3. 使用新类更新原始JAR文件:

    jar uf axis-1.4.jar org \ apache \ axis \ description \ JavaServiceDesc.class org \ apache \ axis \ description \ JavaServiceDesc $ 1.class

这很好,并解决了我的问题。

答案 2 :(得分:0)

似乎您碰到了this错误。

您应该升级到1.4.1或回到JDK7。

另一种选择是在附件diff.txt中应用上述修复程序,并创建axis-rt-core的修补版本(请参见diff.txt)。