[infinispan-issues] [JBoss JIRA] (ISPN-7696) RemoveExpired could be called with updated value

Ryan Emerson (JIRA) issues at jboss.org
Fri Apr 21 05:57:00 EDT 2017


     [ https://issues.jboss.org/browse/ISPN-7696?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ]

Ryan Emerson resolved ISPN-7696.
--------------------------------
    Resolution: Done


> RemoveExpired could be called with updated value
> ------------------------------------------------
>
>                 Key: ISPN-7696
>                 URL: https://issues.jboss.org/browse/ISPN-7696
>             Project: Infinispan
>          Issue Type: Bug
>          Components: Core
>    Affects Versions: 9.0.0.Final
>            Reporter: Radim Vansa
>            Assignee: William Burns
>             Fix For: 9.1.0.Final
>
>
> In {{ClusterExpirationManager.handleLifespanExpireEntry}} the value for {{removeExpired}} is retrieved in the {{Runnable}}, which is not executed under synchronized
> block. There is a comment in CEM.handleInMemoryExpiration about the need
> for synchronization, but it seems to me that the Cache.removeExpired
> does not get the value we're checking the metadata for - there is a
> window when the value can change after we've checked the expiration.
> The value should stored in local variable while under synchronization, and captured in the Runnable/lambda.



--
This message was sent by Atlassian JIRA
(v7.2.3#72005)


More information about the infinispan-issues mailing list