[jbossts-issues] [JBoss JIRA] (JBTM-770) incorrect cleanup registration causes memory leak
Tom Jenkinson (JIRA)
jira-events at lists.jboss.org
Fri Oct 26 09:54:01 EDT 2012
[ https://issues.jboss.org/browse/JBTM-770?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ]
Tom Jenkinson closed JBTM-770.
------------------------------
Resolution: Done
> incorrect cleanup registration causes memory leak
> -------------------------------------------------
>
> Key: JBTM-770
> URL: https://issues.jboss.org/browse/JBTM-770
> Project: JBoss Transaction Manager
> Issue Type: Bug
> Security Level: Public(Everyone can see)
> Components: JTS
> Affects Versions: 4.12.0, 4.6.1.CP06
> Reporter: Jonathan Halliday
> Assignee: Jonathan Halliday
> Fix For: 4.17.0, 4.16.0.Beta1, 4.6.1.CP13, 4.6.1.CP08, 4.13.0
>
>
> jts.TransactionImple constructors attempt to optimize the cleanup callback needed to remove entries from _transactions, bypassing the ORB for interposition scenarios:
> theTx = (TwoPhaseCoordinator) BasicAction.Current();
> if (theTx != null) {
> theTx.addSynchronization(new LocalCleanupSynchronization(this));
> } else {
> registerSynchronization(new CleanupSynchronization(this));
> }
> Unfortunately this does not work and leads to memory leaks on _transactions in certain cases. Specifically, where theTx is a ServerTransaction (i.e. extends ArjunaTransactionImple, which extends TwoPhaseCoordinator), the callbacks run (by ArjunaTransactionImple.do[Before|After]Completion()) are those in ArjunaTransactionImple._syncs, not the masked ones in TwoPhaseCoordinator._syncs. Thus using TwoPhaseCoordinator.addSynchronization registers a callback which is never invoked.
--
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
More information about the jbossts-issues
mailing list