MTOM客户端的OOM异常



我一直致力于传输大尺寸文件,最后以MTOM实现结束。我们创建了支持MTOM的web服务和客户端,并将客户端作为普通Java程序进行了测试。我们成功地发送了1gb的文件。这里的要点是,客户端的堆甚至没有增加超过70 MB。

但是当我试图从web逻辑容器(意味着创建的web客户端)发起相同的调用时,我们最终得到以下OOM Exception。

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)

你知道吗?

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

更新2:似乎weblogic不支持流媒体!我会更新weblogic版本和票证,直到他们祝我好运。

setDomainEnv.sh中添加这个额外的Java/JVM选项

EXTRA_JAVA_PROPERTIES="-DUseSunHttpHandler=true ${EXTRA_JAVA_PROPERTIES}"
export EXTRA_JAVA_PROPERTIES

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

这解决了我的问题。

参考:

在运行jvm时修改HttpURLConnection

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

谢谢!

相关内容

  • 没有找到相关文章

最新更新