[
https://issues.jboss.org/browse/ISPN-2990?page=com.atlassian.jira.plugin....
]
William Burns commented on ISPN-2990:
-------------------------------------
Looking closer it as as Mircea suspected that an OOB message (ClusteredGetCommand) is
being sent while the RemoveCommand (in band) is still being processed. The L1 cache is
only invalidated for nodes that requested the given key and are not the updating node.
The latter is because the updating node just updates it's L1 cache directly and
doesn't query from any of the owning nodes.
So in this case it is very simple to reproduce:
{code}
A owns key k with a value of 1
B removes key k (done async)
B gets key k (receives value 1 since async hasn't completed) and stores in it's L1
cache
A finally removes k and invalidates all known L1 cache values except B's as it was the
requestor
{code}
Just a simple
{code}
cache.remove(k);
cache.get(k);
{code}
would reproduce the issue.
L1ManagerImpl doesn't reliably invalidate with async caches
-----------------------------------------------------------
Key: ISPN-2990
URL:
https://issues.jboss.org/browse/ISPN-2990
Project: Infinispan
Issue Type: Bug
Components: Distributed Cache
Affects Versions: 5.2.1.Final
Reporter: Sebastian Tusk
Assignee: William Burns
Labels: onboard
B is owner of k,v1
A has k,v1 in L1
1. TX: A puts k,v2
2. TX: A sends async PrepareCommand k,v2 to B (one-phase-commit)
3. TX: A removes k,v1 from L1
4. A putForExternalRead k,v1 and has it in L1 again
5. TX: B executes PrepareCommand k,v2 but doesn't send invalidation to origin
Result: A has k,v1 and B has k,v2
Solution: For async caches send invalidation to origin too.
The problem is that the owner updates the cache entry asynchronously. This gives the
origin of the transaction time to request the entry. Here an outdated version is received
and placed in L1. The owner never invalidates the entry and as result the cache is
inconsistent.
--
This message is automatically generated by JIRA.
If you think it was sent incorrectly, please contact your JIRA administrators
For more information on JIRA, see:
http://www.atlassian.com/software/jira