带有 JDK 8 的 AXIS 客户端 1.4 给出 org.apache.axis.AxisFault:java.util.ConcurrentModificationException

问题描述 投票:0回答:4

我使用 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

注意:当我们在 JDK 7 中使用相同的 AXIS 客户端时,根本没有遇到此问题。

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

java soap java-8 axis
4个回答
7
投票

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

AXIS-2909中的建议是从2017年成功的jenkins构建中获取最新的1.4.1-SNAPSHOT。这来自http://svn.apache.org/repos/asf/axis/axis1/java/trunk,简而言之,这个主干自2006年(1.4)以来经历了很多变化,并且尚未正式发布。 - 添加了 Maven 支持 - 完全重组为maven模块 - 很多不同的变化,检查 svn 日志

veithen (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 构建脚本时代。 您还需要包含 j2ee-1.4.jar 作为编译时库。 但接下来你就可以开始了,并且可以烘焙你自己的 1.4.1,其中包含 1.4 +AXIS-2909


1
投票

我按照这种快速而肮脏的方式使用 javac 1.8 修补 axis-1.4.jar:

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

也从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 axis-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 pache xis\description\JavaServiceDesc.class org pache xis\description\JavaServiceDesc$1.class

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


0
投票

您似乎遇到了这个错误。

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

另一种选择可能是应用所附 diff.txt 中提到的修复并创建 axis-rt-core 的修补版本(请参阅 diff.txt)。


0
投票

使用 java 8 Windows cmd 编译:

javac -cp“.;axis-1.4.jar;axis-jaxrpc-1.4.jar;commons-logging-1.1.1.jar”JavaServiceDesc.java

用新类更新原始 JAR 文件是相同的:

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

© www.soinside.com 2019 - 2024. All rights reserved.