Hi Andrea,

Yes, I run application using jar file. Java has 1G heap.

Actually I assumed that camel will not read file in single string, but will
use InputStream to read the data.

2016-10-19 15:28 GMT+03:00 Andrea Cosentino <ancosen1...@yahoo.com.invalid>:

> Is the camel-context deployed as a simple JAR? What are you using inside
> the Debian container? How much memory has your container?
> Did you set JVM_OPTS witch specific values for max Heap size and min Heap
> size?
>
>  --
> Andrea Cosentino
> ----------------------------------
> Apache Camel PMC Member
> Apache Karaf Committer
> Apache Servicemix Committer
> Email: ancosen1...@yahoo.com
> Twitter: @oscerd2
> Github: oscerd
>
>
>
> On Wednesday, October 19, 2016 2:00 PM, Vova Shelgunov <vvs...@gmail.com>
> wrote:
> Hi,
>
> I catched this OutOfMemoryError when I sent a 250 MB file to jetty
> endpoint:
>
> java.lang.OutOfMemoryError: Java heap space
>       at java.lang.StringCoding.decode(StringCoding.java:215)
>       at java.lang.String.<init>(String.java:463)
>       at java.lang.String.<init>(String.java:515)
>       at
> org.eclipse.jetty.servlets.MultiPartFilter$Wrapper.
> getParameterBytesAsString(MultiPartFilter.java:390)
>       at
> org.eclipse.jetty.servlets.MultiPartFilter$Wrapper.getParameterValues(
> MultiPartFilter.java:337)
>       at
> org.apache.camel.http.common.DefaultHttpBinding.populateRequestParameters(
> DefaultHttpBinding.java:219)
>       at
> org.apache.camel.http.common.DefaultHttpBinding.readHeaders(
> DefaultHttpBinding.java:174)
>       at
> org.apache.camel.http.common.DefaultHttpBinding.readRequest(
> DefaultHttpBinding.java:110)
>       at
> org.apache.camel.http.common.HttpMessage.<init>(HttpMessage.java:52)
>       at
> org.apache.camel.component.jetty.CamelContinuationServlet.doService(
> CamelContinuationServlet.java:161)
>       at
> org.apache.camel.http.common.CamelServlet.service(CamelServlet.java:74)
>       at javax.servlet.http.HttpServlet.service(HttpServlet.java:790)
>       at
> org.eclipse.jetty.servlet.ServletHolder.handle(ServletHolder.java:812)
>       at
> org.eclipse.jetty.servlet.ServletHandler$CachedChain.
> doFilter(ServletHandler.java:1669)
>       at
> org.eclipse.jetty.servlets.MultiPartFilter.doFilter(
> MultiPartFilter.java:200)
>       at
> org.apache.camel.component.jetty.CamelFilterWrapper.
> doFilter(CamelFilterWrapper.java:43)
>       at
> org.eclipse.jetty.servlet.ServletHandler$CachedChain.
> doFilter(ServletHandler.java:1652)
>       at
> org.eclipse.jetty.servlet.ServletHandler.doHandle(ServletHandler.java:585)
>       at
> org.eclipse.jetty.server.handler.ContextHandler.
> doHandle(ContextHandler.java:1127)
>       at
> org.eclipse.jetty.servlet.ServletHandler.doScope(ServletHandler.java:515)
>       at
> org.eclipse.jetty.server.handler.ContextHandler.
> doScope(ContextHandler.java:1061)
>       at
> org.eclipse.jetty.server.handler.ScopedHandler.handle(
> ScopedHandler.java:141)
>       at
> org.eclipse.jetty.server.handler.HandlerWrapper.handle(
> HandlerWrapper.java:97)
>       at org.eclipse.jetty.server.Server.handle(Server.java:499)
>       at org.eclipse.jetty.server.HttpChannel.handle(HttpChannel.java:311)
>       at
> org.eclipse.jetty.server.HttpConnection.onFillable(
> HttpConnection.java:257)
>       at
> org.eclipse.jetty.io.AbstractConnection$2.run(AbstractConnection.java:544)
>       at
> org.eclipse.jetty.util.thread.QueuedThreadPool.runJob(
> QueuedThreadPool.java:635)
>       at
> org.eclipse.jetty.util.thread.QueuedThreadPool$3.run(
> QueuedThreadPool.java:555)
>       at java.lang.Thread.run(Thread.java:745)
>
> My configuration:
>
> <route id="ds-rest-archive-upload-processor">
> <from uri="jetty:
> https://storage:8443/data/archive?sslContextParametersRef=
> sslContextParameters&requestBufferSize=32768&responseBufferSize=32768&
> httpMethodRestrict=POST
> <https://storage:8443/data/archive?sslContextParametersRef=
> sslContextParameters&requestBufferSize=32768&responseBufferSize=32768&
> httpMethodRestrict=POST>"
> />
>
> <to uri="bean:uploadFromArchiveFileProcessor?method=process"
> pattern="InOut" />
>
> </route>
>
> <bean id="jetty"
> class="org.apache.camel.component.jetty9.JettyHttpComponent9">
> <property name="endpointClass"
> value="org.apache.camel.component.jetty9.JettyHttpEndpoint9" />
> <property name="sslContextParameters" ref="sslContextParameters" />
> <property name="useContinuation" value="true" />
> <property name="requestBufferSize" value="32768" />
> <property name="responseBufferSize" value="32768" />
>
> <property name="threadPool">
> <bean class="org.eclipse.jetty.util.thread.QueuedThreadPool">
> <constructor-arg index="0" value="1000" />
> </bean>
> </property>
>
> <property name="jettyHttpBinding">
> <bean class="org.apache.camel.component.jetty.DefaultJettyHttpBinding">
> <property name="transferException" value="false" />
> </bean>
> </property>
> </bean>
>
> My camel application is running in docker container with limited amount of
> memory, and I did not expect, that a file will be read a string instead of
> reading from InputStream.
>
> Is there any way to consume large files with small amount of memory?
>
>
> Regards,
>
> Uladzimir
>

Reply via email to