[ 
https://issues.apache.org/jira/browse/AXIS2-2574?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
 ]

Dirk Niededir resolved AXIS2-2574.
----------------------------------

    Resolution: Incomplete

I've updated the AXIOM to 1.4 within the Webapp. The blocksize has changed from 
1 byte to 4000. So this is fixed.

But now I get an OutOfMemory-Error after the Axis*.att-File has been written 
completely to Disk. The Error is thrown before the Method invokeBusinessLogic 
of my class (RawXMLINOutMessageReceiver) is reached. Whats wrong? The file is 
about 50MB and "-Xmx=256m"

Stacktrace:
Thread [http-8081-Processor24] (Suspended (exception 
java.lang.OutOfMemoryError))       
        org.apache.axiom.om.impl.llom.OMTextImpl.getText() line: 223    
        
org.apache.axiom.om.impl.llom.OMTextImpl.writeOutput(javax.xml.stream.XMLStreamWriter)
 line: 209        
        
org.apache.axiom.om.impl.llom.OMTextImpl.internalSerializeLocal(javax.xml.stream.XMLStreamWriter)
 line: 387     
        
org.apache.axiom.om.impl.llom.OMTextImpl.internalSerialize(javax.xml.stream.XMLStreamWriter)
 line: 197  
        
org.apache.axiom.om.impl.llom.OMElementImpl.internalSerialize(javax.xml.stream.XMLStreamWriter,
 boolean) line: 766      
        
org.apache.axiom.om.impl.llom.OMElementImpl.internalSerialize(javax.xml.stream.XMLStreamWriter)
 line: 750       
        
org.apache.axiom.om.impl.llom.OMElementImpl.internalSerialize(javax.xml.stream.XMLStreamWriter,
 boolean) line: 766      
        
org.apache.axiom.om.impl.llom.OMElementImpl.internalSerialize(javax.xml.stream.XMLStreamWriter)
 line: 750       
        
org.apache.axiom.soap.impl.llom.soap11.SOAP11BodyImpl(org.apache.axiom.om.impl.llom.OMElementImpl).internalSerialize(javax.xml.stream.XMLStreamWriter,
 boolean) line: 766       
        
org.apache.axiom.soap.impl.llom.soap11.SOAP11BodyImpl(org.apache.axiom.om.impl.llom.OMElementImpl).internalSerialize(javax.xml.stream.XMLStreamWriter)
 line: 750        
        
org.apache.axiom.soap.impl.llom.SOAPEnvelopeImpl.internalSerialize(javax.xml.stream.XMLStreamWriter,
 boolean) line: 207 
        
org.apache.axiom.soap.impl.llom.SOAPEnvelopeImpl(org.apache.axiom.om.impl.llom.OMElementImpl).internalSerialize(javax.xml.stream.XMLStreamWriter)
 line: 750     
        
org.apache.axiom.soap.impl.llom.SOAPEnvelopeImpl(org.apache.axiom.om.impl.llom.OMNodeImpl).serialize(javax.xml.stream.XMLStreamWriter)
 line: 342        
        
org.apache.axiom.soap.impl.llom.SOAPEnvelopeImpl(org.apache.axiom.om.impl.llom.OMElementImpl).toString()
 line: 907      
        
org.apache.axis2.handlers.soapmonitor.SOAPMonitorHandler.invoke(org.apache.axis2.context.MessageContext)
 line: 98       
        
org.apache.axis2.engine.Phase.invoke(org.apache.axis2.context.MessageContext) 
line: 382 
        
org.apache.axis2.engine.AxisEngine.invoke(org.apache.axis2.context.MessageContext)
 line: 522    
        
org.apache.axis2.engine.AxisEngine.receive(org.apache.axis2.context.MessageContext)
 line: 487   
        
org.apache.axis2.transport.http.HTTPTransportUtils.processHTTPPostRequest(org.apache.axis2.context.MessageContext,
 java.io.InputStream, java.io.OutputStream, java.lang.String, java.lang.String, 
java.lang.String) line: 328   
        
org.apache.axis2.transport.http.AxisServlet.doPost(javax.servlet.http.HttpServletRequest,
 javax.servlet.http.HttpServletResponse) line: 254     
        
org.apache.axis2.transport.http.AxisServlet(javax.servlet.http.HttpServlet).service(javax.servlet.http.HttpServletRequest,
 javax.servlet.http.HttpServletResponse) line: 710    
        
org.apache.axis2.transport.http.AxisServlet(javax.servlet.http.HttpServlet).service(javax.servlet.ServletRequest,
 javax.servlet.ServletResponse) line: 803      
        
org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(javax.servlet.ServletRequest,
 javax.servlet.ServletResponse) line: 269 
        
org.apache.catalina.core.ApplicationFilterChain.doFilter(javax.servlet.ServletRequest,
 javax.servlet.ServletResponse) line: 188 
        
org.apache.catalina.core.StandardWrapperValve.invoke(org.apache.catalina.connector.Request,
 org.apache.catalina.connector.Response) line: 210   
        
org.apache.catalina.core.StandardContextValve.invoke(org.apache.catalina.connector.Request,
 org.apache.catalina.connector.Response) line: 174   
        
org.apache.catalina.valves.AccessLogValve.invoke(org.apache.catalina.connector.Request,
 org.apache.catalina.connector.Response) line: 542       
        
org.apache.catalina.core.StandardHostValve.invoke(org.apache.catalina.connector.Request,
 org.apache.catalina.connector.Response) line: 127      
        
org.apache.catalina.valves.ErrorReportValve.invoke(org.apache.catalina.connector.Request,
 org.apache.catalina.connector.Response) line: 117     
        
org.apache.catalina.core.StandardEngineValve.invoke(org.apache.catalina.connector.Request,
 org.apache.catalina.connector.Response) line: 108    
        
org.apache.catalina.connector.CoyoteAdapter.service(org.apache.coyote.Request, 
org.apache.coyote.Response) line: 151    
        org.apache.coyote.http11.Http11Processor.process(java.io.InputStream, 
java.io.OutputStream) line: 870   
        
org.apache.coyote.http11.Http11Protocol$JmxHttp11ConnectionHandler(org.apache.coyote.http11.Http11BaseProtocol$Http11ConnectionHandler).processConnection(org.apache.tomcat.util.net.TcpConnection,
 java.lang.Object[]) line: 665       
        
org.apache.tomcat.util.net.PoolTcpEndpoint.processSocket(java.net.Socket, 
org.apache.tomcat.util.net.TcpConnection, java.lang.Object[]) line: 528       
        
org.apache.tomcat.util.net.LeaderFollowerWorkerThread.runIt(java.lang.Object[]) 
line: 81        
        org.apache.tomcat.util.threads.ThreadPool$ControlRunnable.run() line: 
685       
        
org.apache.tomcat.util.threads.ThreadWithAttributes(java.lang.Thread).run() 
line: 595   


> usage of attachments is very slow when they are cached on disk (Server-Side)
> ----------------------------------------------------------------------------
>
>                 Key: AXIS2-2574
>                 URL: https://issues.apache.org/jira/browse/AXIS2-2574
>             Project: Axis 2.0 (Axis2)
>          Issue Type: Bug
>    Affects Versions: 1.1.1
>         Environment: SUN JRE 5.0 Update 11, Apache Tomcat 5.5.23, Windows XP 
> Professional
>            Reporter: Dirk Niededir
>         Assigned To: Thilina Gunarathne
>
> I have implemented a small AXIOM based Service using the AXIS2 1.1.1 WAR-file.
> I am using the DataHandler to receive big Byte-Arrays (base64binary). Using 
> MTOM, AXIS2 is converting them to attachments. This works fine using small 
> Byte-Arrays. To avoid a OutOfMemoryError, I enabled the file based cache 
> using the parameters cacheAttachments=true, attachmentDIR=cachedir and 
> sizeThreshold=30000 in the axis2.conf. This still works fine but very slow, 
> if the size is greater than sizeThreshold. I know File access should be 
> slower than using RAM. But this works much slower than it should and the CPU 
> is at maximum. 
> Using the Windows-Tool "Process Monitor" ( 
> http://www.microsoft.com/technet/sysinternals/utilities/processmonitor.mspx 
> ), I saw that the axis*.att files are written in blocks with size=1. This 
> might be a hint.
> For this I have written a small test, which writes a 50MB file to disk either 
> buffered or unbuffered:
> --------------------------
>       File file = new File( "C:/java/temp/test.txt");
>       if( file.exists())
>               file.delete();
>       file.createNewFile();
>       long startTime = System.currentTimeMillis();
>       
>       OutputStream fos = new FileOutputStream( file);
>       boolean buffered = true;
>       if( buffered)
>               fos = new BufferedOutputStream( fos);
>       
>       int count = 0;
>       while( count < 50*1000000) {
>               count++;
>               fos.write( 'a');
>       }
>       fos.close();
>       
>       long endTime = System.currentTimeMillis();
>       
>       System.out.println("time = "+(endTime-startTime)+"ms");
> --------------------------
> if the buffered-flag is false, then time = 203360ms and CPU ~ 90%
> if the buffered-flag is true,  then time = 2763ms       and CPU ~ 30%
> The buffered version is 73.6 times faster with a much lower CPU utilization!
> This confirms to the hint. So decoration of the FileOutputStream for the 
> axis*.att-Files with a BufferedOutputStream will fix this "bug". 
> Maybe it is a Windows-Problem, but the decoration will not be a disadvantage 
> for other systems.

-- 
This message is automatically generated by JIRA.
-
You can reply to this email to add a comment to the issue online.


---------------------------------------------------------------------
To unsubscribe, e-mail: [EMAIL PROTECTED]
For additional commands, e-mail: [EMAIL PROTECTED]

Reply via email to