gpt4 book ai didi

java - Eclipse 生成的 Web 服务客户端非常慢

转载 作者:塔克拉玛干 更新时间:2023-11-03 03:54:01 25 4
gpt4 key购买 nike

一些前期信息:

我有一个 SOAP 服务(使用 JAX-WS(端点类)托管,但我认为这不重要)。

我可以通过 Visual Studio 生成客户端 (C#) 连接并使用 Web 服务。

我使用 Eclipse Web 工具生成了一个 Java 客户端(新 --> 其他 --> Web 服务 --> Web 服务客户端)。

然后我写了一个JUnit测试来测试客户端。测试通过,但运行时间非常长。每个服务调用需要 300 秒(几秒钟)。此外,计算机的速度有多快并不重要。如果我在我工作速度非常慢的笔记本电脑上运行它,它所花费的时间与我在我的快速家用机器上运行它所花费的时间相同。

我已将 Axis 代码调试到 org.apache.axis.encoding.DeserializationContext 中的以下函数:

public void parse() throws SAXException
{
if (inputSource != null) {
SAXParser parser = XMLUtils.getSAXParser();
try {
parser.setProperty("http://xml.org/sax/properties/lexical-handler", this);
parser.parse(inputSource, this);

try {
// cleanup - so that the parser can be reused.
parser.setProperty("http://xml.org/sax/properties/lexical-handler", nullLexicalHandler);
} catch (Exception e){
// Ignore.
}

不出所料,但对 parser.parse() 的调用占用了 300 秒。来自 Web 服务的内容非常短,因此解析应该不会花费太多时间。

如果有人想知道,解析器的实际类型是 com.sun.org.apache.xerces.internal.jaxp.SAXParserImpl

我无法调试它,因为我没有源代码(而且我厌倦了深入调试常用库的 50 个调用)。

我目前正在运行分析器以包含来自 Sun 的软件包。完成后我会发布我的发现(添加所有这些包会显着减慢测试速度)

我正在运行 Eclipse 3.5.1 并且我正在使用 axis 1.4

编辑:

这是 JUnit 测试:

@Test
public void testExecuter() throws IOException, InterruptedException, RemoteException, ServiceException
{
//Listener l = new Listener(3456);
//l.start();
Executer exec = new ExecuterServiceLocator().getExecuterPort();
//Executer exec = new ExecuterProxy("http://localhost:3456/Executer");
System.out.println("executer created");
_return remote = exec.execute("perl -e \"print 5\"", new EvAction[0]);
System.out.println("after call 1");
assertEquals("5", remote.getStdout());
assertEquals("", remote.getStderr());
assertEquals(0, remote.getReturnCode());
}

注意:两种创建执行器的方式都会发生同样的事情

编辑2:

这是我用来启动服务的代码:

public static void main(String[] args) {
Endpoint.create(new Executer()).publish("http://localhost:3456/Executer");
}

我无法发布 URL,因为我现在只是在一台机器上开发它。但是,这是如果我转到 http://localhost:3456/Executer?WSDL 时生成的 WSDL

<!--
Published by JAX-WS RI at http://jax-ws.dev.java.net. RI's version is JAX-WS RI 2.1.6 in JDK 6.
-->

<!--
Generated by JAX-WS RI at http://jax-ws.dev.java.net. RI's version is JAX-WS RI 2.1.6 in JDK 6.
-->

<definitions targetNamespace="http://executer/" name="ExecuterService">

<types>

<xsd:schema>
<xsd:import namespace="http://executer/" schemaLocation="http://localhost:3456/Executer?xsd=1"/>
</xsd:schema>
</types>

<message name="Execute">
<part name="parameters" element="tns:Execute"/>
</message>

<message name="ExecuteResponse">
<part name="parameters" element="tns:ExecuteResponse"/>
</message>

<message name="IOException">
<part name="fault" element="tns:IOException"/>
</message>

<message name="InterruptedException">
<part name="fault" element="tns:InterruptedException"/>
</message>

<portType name="Executer">

<operation name="Execute">
<input message="tns:Execute"/>
<output message="tns:ExecuteResponse"/>
<fault message="tns:IOException" name="IOException"/>
<fault message="tns:InterruptedException" name="InterruptedException"/>
</operation>
</portType>

<binding name="ExecuterPortBinding" type="tns:Executer">
<soap:binding transport="http://schemas.xmlsoap.org/soap/http" style="document"/>

<operation name="Execute">
<soap:operation soapAction=""/>

<input>
<soap:body use="literal"/>
</input>

<output>
<soap:body use="literal"/>
</output>

<fault name="IOException">
<soap:fault name="IOException" use="literal"/>
</fault>

<fault name="InterruptedException">
<soap:fault name="InterruptedException" use="literal"/>
</fault>
</operation>
</binding>

<service name="ExecuterService">

<port name="ExecuterPort" binding="tns:ExecuterPortBinding">
<soap:address location="http://localhost:3456/Executer"/>
</port>
</service>
</definitions>

编辑:

我认为这可能会导致问题:

我使用 TCPMonitor 查看 SOAP 请求,我注意到客户端使用 HTTP/1.0 而服务器使用 HTTP/1.1,但我不知道这是否导致了问题。我目前正试图弄清楚如何让客户端使用 HTTP/1.1。

以下是 SOAP 消息,以防有人疑惑:

POST /Executer HTTP/1.0
Content-Type: text/xml; charset=utf-8
Accept: application/soap+xml, application/dime, multipart/related, text/*
User-Agent: Axis/1.4
Host: USENBOONETL1C:2222
Cache-Control: no-cache
Pragma: no-cache
SOAPAction: ""
Content-Length: 354

<?xml version="1.0" encoding="UTF-8"?><soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"><soapenv:Body><Execute xmlns="http://executer/"><arg0 xmlns="">perl -e &quot;print 5&quot;</arg0></Execute></soapenv:Body></soapenv:Envelope>

和响应:

HTTP/1.1 200 OK
Content-type: text/xml;
charset="utf-8"
Content-length: 266

<?xml version="1.0" ?><S:Envelope xmlns:S="http://schemas.xmlsoap.org/soap/envelope/"><S:Body><ns2:ExecuteResponse xmlns:ns2="http://executer/"><return><stdout>5</stdout><stderr></stderr><returnCode>0</returnCode></return></ns2:ExecuteResponse></S:Body></S:Envelope>

编辑:

终于!结果将 HTTP 客户端更改为 CommonsHTTPClient 并使用 HTTP/1.1 解决了问题:

这是我添加到客户端的修复它的代码:

BasicClientConfig basicClientConfig = new BasicClientConfig();
SimpleChain simpleChain = new SimpleChain();

simpleChain.addHandler(new CommonsHTTPSender());
basicClientConfig.deployTransport("http", simpleChain);

ExecuterServiceLocator l = new ExecuterServiceLocator(basicClientConfig);
...

注意:您必须将 common-httpclient.jarcommon.codec.jar 添加到类路径。

最佳答案

我遇到了同样的问题,修改http版本解决了。

一个更简单的方法是,在 stub 类中,调用 Call 实例的 setProperty 方法:

_call.setProperty(MessageContext.HTTP_TRANSPORT_VERSION,HTTPConstants.HEADER_PROTOCOL_V11);

关于java - Eclipse 生成的 Web 服务客户端非常慢,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1985963/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com