[infinispan-issues] [JBoss JIRA] (ISPN-4573) Unable to serialize List<LuceneWork>

Radim Vansa (JIRA) issues at jboss.org
Fri Jul 25 09:29:30 EDT 2014


Radim Vansa created ISPN-4573:
---------------------------------

             Summary: Unable to serialize List<LuceneWork>
                 Key: ISPN-4573
                 URL: https://issues.jboss.org/browse/ISPN-4573
             Project: Infinispan
          Issue Type: Bug
      Security Level: Public (Everyone can see)
          Components: Embedded Querying
    Affects Versions: 7.0.0.Alpha5
            Reporter: Radim Vansa
            Assignee: Sanne Grinovero


When I try to fill distributed cache with indexing enabled concurrently from multiple threads, I get 
{code}
org.hibernate.search.exception.SearchException: HSEARCH000083: Unable to serialize List<LuceneWork>
        at org.hibernate.search.indexes.serialization.impl.LuceneWorkSerializerImpl.toSerializedModel(LuceneWorkSerializerImpl.java:92)
...
Caused by: java.lang.ArrayIndexOutOfBoundsException: 6
        at java.util.ArrayList.add(ArrayList.java:412)
        at org.hibernate.search.indexes.serialization.avro.impl.AvroSerializer.addFieldWithStringData(AvroSerializer.java:258)
        at org.hibernate.search.indexes.serialization.impl.LuceneWorkSerializerImpl.buildDocument(LuceneWorkSerializerImpl.java:174)
        at org.hibernate.search.indexes.serialization.impl.LuceneWorkSerializerImpl.toSerializedModel(LuceneWorkSerializerImpl.java:80)
{code}

There are multiple different exceptions as cause, but the reason is one: {{AvroSerializer}} is not thead-safe. {{AvroSerializerProvider}} returns always the same instance, and so does {{InfinispanIndexManager}} (or rather {{DirectoryBasedIndexManager}}) return the same instance of {{LuceneWorkSerializerImpl}} wrapping the {{AvroSerializerProvider}}.

This results in failed writes, corrupted data and another fun.



--
This message was sent by Atlassian JIRA
(v6.2.6#6264)


More information about the infinispan-issues mailing list