]
William Burns updated ISPN-4810:
--------------------------------
Fix Version/s: 5.2.13.Final
5.2.12.Final
(was: 5.2.11.Final)
Local Transactional Cache loses data when eviction is enabled and
there are multiple readers and one writer
-----------------------------------------------------------------------------------------------------------
Key: ISPN-4810
URL:
https://issues.jboss.org/browse/ISPN-4810
Project: Infinispan
Issue Type: Bug
Affects Versions: 6.0.2.Final
Environment: Windows 7 x64 (NTFS)
Oracle JDK1.7.0_40
Apache Maven 3.0.5
Reporter: Horia Chiorean
Assignee: William Burns
Labels: modeshape
Fix For: 7.2.0.Beta1, 5.2.12.Final, 5.2.13.Final
Attachments: ispn_concurrent.zip
Using Infinispan 6.0.2 and a local, transactional cache backed by a <singleFile>
store, with eviction enabled and a small {{max-entries}} setting, we have the following
scenario:
* the main thread (i.e. the "writer") starts a transaction, adds a batch of
strings into the cache and also appends the same strings into a List cache entry and then
commits the transaction
* after the above has finished (i.e. after tx.commit) it fires a number of reader threads
where each reader thread
** checks that the string entries were added into the cache and
** checks that the entries were correctly appended to the List entry
* the above steps are repeated a number of times
On any given run, based on timing, we're seeing that at some point (after some time)
some of the reader threads will not see the latest version of the List entry (i.e. will
not see the latest elements that were added into the list) but rather an old, stale List
(sort of a "lost update" scenario).
If we either:
* disable eviction or
* set the {{max-entries}} to a large enough value (which I suspect has the same effect -
not evicting anything) the problem doesn't show up.