[
https://issues.redhat.com/browse/TEIID-5887?page=com.atlassian.jira.plugi...
]
Steven Hawkins resolved TEIID-5887.
-----------------------------------
Resolution: Done
Changed the marshalling logic so that it can be done lazily.
Issues with marhaller registration
----------------------------------
Key: TEIID-5887
URL:
https://issues.redhat.com/browse/TEIID-5887
Project: Teiid
Issue Type: Bug
Components: Infinispan
Reporter: Steven Hawkins
Assignee: Steven Hawkins
Priority: Major
Fix For: 13.1
Original Estimate: 6 hours
Time Spent: 7 hours
Remaining Estimate: 0 minutes
Adding transactional logic to infinispan highlights several problems with marshaller
registration. The first is that all connections are working off of a shared context and
each registering a marshaller for the same class type - this is not thread safe.
The other issue specific to transactions is that some operations are delayed or redone at
commit time - which is called after the connection is closed potentially in a different
thread and thus the marshaller provider has been removed. Given the interplay of threads
using a thread local won't work.
Potentially a transaction aware thread pool or the use of something like our execution
context keep alive may be needed.
--
This message was sent by Atlassian Jira
(v7.13.8#713008)