MTOM客户端的OOM异常

时间:2014-08-25 10:09:31

标签: weblogic mtom

我正在研究传输大型文件,最后以MTOM实现结束。我们创建了支持MTOM的Web服务和客户端,并将客户端作为普通的Java程序进行了测试。我们能够成功发送1 GB文件。这里的主要观点是客户端的堆甚至没有增加超过70 MB。

但是当我尝试从网络逻辑容器(意味着创建的Web客户端)启动相同的调用时,我们最终会遇到OOM异常。

at

weblogic.utils.io.UnsyncByteArrayOutputStream.resizeBuffer(UnsyncByteArrayOutputStream.java:59)
      at weblogic.utils.io.UnsyncByteArrayOutputStream.write(UnsyncByteArrayOutputStream.java:89)
      at javax.activation.DataHandler.writeTo(DataHandler.java:293)
      at com.sun.xml.ws.encoding.MtomCodec$ByteArrayBuffer.write(MtomCodec.java:196)
      at com.sun.xml.ws.encoding.MtomCodec.encode(MtomCodec.java:163)
      at com.sun.xml.ws.encoding.SOAPBindingCodec.encode(SOAPBindingCodec.java:258)
      at com.sun.xml.ws.transport.http.client.HttpTransportPipe.process(HttpTransportPipe.java:142)
      at com.sun.xml.ws.transport.http.client.HttpTransportPipe.processRequest(HttpTransportPipe.java:86)
      at com.sun.xml.ws.api.pipe.Fiber.__doRun(Fiber.java:598)
      at com.sun.xml.ws.api.pipe.Fiber._doRun(Fiber.java:557)
      at com.sun.xml.ws.api.pipe.Fiber.doRun(Fiber.java:542)
      at com.sun.xml.ws.api.pipe.Fiber.runSync(Fiber.java:439)
      at com.sun.xml.ws.client.Stub.process(Stub.java:248)
      at com.sun.xml.ws.client.sei.SEIStub.doProcess(SEIStub.java:135)
      at com.sun.xml.ws.client.sei.SyncMethodHandler.invoke(SyncMethodHandler.java:109)
      at com.sun.xml.ws.client.sei.SyncMethodHandler.invoke(SyncMethodHandler.java:89)
      at com.sun.xml.ws.client.sei.SEIStub.invoke(SEIStub.java:118)
      at $Proxy101.uploadFile(Unknown Source)

任何人都有任何想法

更新:当我们在网络逻辑容器中运行程序时,MTOM设置似乎无效!但我仍然无法找到解决方案

更新2:似乎weblogic不支持流式传输!我将更新weblogic版本并更新票证,直到他们祝我好运..

1 个答案:

答案 0 :(得分:-1)

setDomainEnv.sh

中添加此额外的Java / JVM选项
EXTRA_JAVA_PROPERTIES="-DUseSunHttpHandler=true ${EXTRA_JAVA_PROPERTIES}"
export EXTRA_JAVA_PROPERTIES

从特定于weblogic(weblogic.net.http.HttpURLConnection)切换到sun的HTTP处理程序。

这解决了我的问题。

参见:

Changing HttpURLConnection in running jvm

http://atgtipsandtweaks.blogspot.com/2011/11/weblogicjava-httphandler-issues.html

谢谢!