[ 
https://issues.apache.org/jira/browse/COCOON-2340?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=13834654#comment-13834654
 ] 

Javier Puerto commented on COCOON-2340:
---------------------------------------

Hi,

I've more familiar with the 2.2 version. I've experienced issues like you 
described and it was by the following reasons, now works like a charm :). So, 
could you check the following?

* The components in the pipeline was declared as singleton instead of 
prototype. Some components are not thread safe, use prototype scope to avoid 
this problem.
* The version 2.2 is using an older version of Apache Xalan. Upgrade to 2.2.1 
or upgrade Xalan to latest, see COCOON-2156.

Anyway, could you provide an example to reproduce the problem if it persists?

Salu2.

> XMLByteStreamCompiler in not thread-safe
> ----------------------------------------
>
>                 Key: COCOON-2340
>                 URL: https://issues.apache.org/jira/browse/COCOON-2340
>             Project: Cocoon
>          Issue Type: Bug
>          Components: * Cocoon Core
>    Affects Versions: 2.2
>            Reporter: Ivan Lagunov
>
> I'm periodically getting the following exceptions in different places:
> Caused by: java.lang.ArrayIndexOutOfBoundsException
>         at java.lang.System.arraycopy(Native Method)
>         at 
> org.apache.cocoon.components.sax.XMLByteStreamCompiler.getSAXFragment(XMLByteStreamCompiler.java:61)
>         at 
> org.apache.cocoon.components.pipeline.impl.ExpiresCachingProcessingPipeline.processXMLPipeline(ExpiresCachingProcessingPipeline.java:152)
> After debugging I've found the root cause. It happens due to multi-threading 
> when one thread allocates newbuf array, then another thread increments 
> bufCount in write method and then the first thread fails on System.arraycopy 
> invocation.
> I suggest making getSAXFragment and write methods synchronized. It should 
> resolve the issue. If it helps, I'll provide a patch later.



--
This message was sent by Atlassian JIRA
(v6.1#6144)

Reply via email to