[
https://jira.jboss.org/jira/browse/EJBTHREE-1501?page=com.atlassian.jira....
]
Galder Zamarreno commented on EJBTHREE-1501:
--------------------------------------------
Re: hold lock during long running call.
Indeed, I thought of that while trying to figure out why it had been
coded that way. There's a similar thing happening when a bean is
activated from passivation.
Re: scenario/problem
There's not a real problem/scenario at the moment.
Hmmm, thinking through it, I can't think of a realistic scenario or
significant scenario where this issue is relevant. Example: could
be some issue if removal and passivation timeout where the
same and both kicked in at the same time.
Operations on cacheMap are not thread safe
------------------------------------------
Key: EJBTHREE-1501
URL:
https://jira.jboss.org/jira/browse/EJBTHREE-1501
Project: EJB 3.0
Issue Type: Sub-task
Affects Versions: AS 4.2.3.GA, 1.0.0-Beta3
Reporter: Galder Zamarreno
Assignee: Galder Zamarreno
Finally, code like this is not thread safe:
synchronized (cacheMap)
{
ctx = (StatefulBeanContext) cacheMap.get(key);
}
if(ctx == null)
throw new NoSuchEJBException("Could not find Stateful bean: " + key);
if (!ctx.isRemoved())
container.destroy(ctx);
++removeCount;
if (ctx.getCanRemoveFromCache())
{
synchronized (cacheMap)
{
cacheMap.remove(key);
}
}
This is essentiall a removeIfPresent type of operation on cacheMap and hence
get() and remove() operation, as they depend on each other, should be in a
single synchronized statement. Example:
synchronized (cacheMap)
{
ctx = (StatefulBeanContext) cacheMap.get(key);
if(ctx == null)
throw new NoSuchEJBException("Could not find Stateful bean: " +
key);
if (!ctx.isRemoved())
container.destroy(ctx);
++removeCount;
if (ctx.getCanRemoveFromCache())
{
cacheMap.remove(key);
}
}
--
This message is automatically generated by JIRA.
-
If you think it was sent incorrectly contact one of the administrators:
https://jira.jboss.org/jira/secure/Administrators.jspa
-
For more information on JIRA, see:
http://www.atlassian.com/software/jira