Skip to main content

Notice: this Wiki will be going read only early in 2024 and edits will no longer be possible. Please see: https://gitlab.eclipse.org/eclipsefdn/helpdesk/-/wikis/Wiki-shutdown-plan for the plan.

Jump to: navigation, search

EclipseLink/DesignDocs/214661

< EclipseLink‎ | DesignDocs
Revision as of 11:57, 30 April 2008 by Gordon.yorke.oracle.com (Talk | contribs)

(diff) ← Older revision | Latest revision (diff) | Newer revision → (diff)

Functional Specification: VM managed Entity detachment

ER 214661

Feedback

Document History

Date Author Version Description & Notes
April 23, 2008 Gordon Yorke Initial Proposal
April 28, 2008 Gordon Yorke Based on feedback
April 30, 2008 Gordon Yorke Updated Java Doc

Project overview

Allowing a Persistence Context to reference managed objects in a weak manner provides an automatic memory management mechanism for rich clients and like users.

Currently JPA clients must manage memory foot print manually by controlling the lifetime of the PersistenceContext as well as the contents of the Persistence Context.

Within a Rich Client environment it is much easier for application developers to simply use the managed objects as the UI backing objects and leverage transparent persistence instead of creating a DOA layer. With this approach Persistence Contexts tend to grow and detaching objects is problematic.

With this feature memory management can be delegated to the VMs garbage collection functionality through the use of weak references. Having non changed objects removed from the Persistence Context also reduces the number of objects that must be processed during database flush, potentially improving performance.

Functionality

Adding a Reference Mode Enum and API’s to allow users to control how EclipseLink references managed objects.
• When “HARD” mode is chosen all objects are referenced by hard Java references and are not available for GC. This continues to be the default mode for EclipsLink
• When “WEAK“ mode is chosen EclipseLink will reference all changed tracked objects though weak references. This means any object no longer referenced directly or indirectly will be available for garbage collection. If the object is gc’d before the EM/UnitOfWork flushes to the database then this object and any others like it will not be checked for changes. When a change is made to a change tracked object that object is moved to a hard reference and will not be available for GC until flushed. New and removed objects are also held by hard references. Non change tracked objects will always be held by “hard” references and are not available for GC.
• When “FORCE-WEAK” mode is chosen all objects including non change tracked objects are held by weak references. When a change is made to a change tracked object that object is moved to a hard reference and will not be available for GC until flushed. New and removed objects are also held by hard references until flush.

package org.eclipse.persistence.sessions.factories;
 
public enum ReferenceMode {
    /**
     * References to Objects will be through hard references.  These objects will not be available for
     * garbage collection until the referencing artifact (usually a Persistence Context or UnitOfWork)
     * released or closed.
     */
    HARD,
 
    /**
     * References to Objects that support active attribute change tracking
     * (enabled through weaving or by the developer)will be held by weak
     * references. This means any of afore mentioned objects no longer referenced directly or
     * indirectly will be available for garbage collection. If the object is
     * gc’d before the EM/UnitOfWork flushes to the database then this object
     * and any others like it will not be checked for changes. When a change is
     * made to a change tracked object that object is moved to a hard reference
     * and will not be available for GC until flushed. New and removed objects
     * are also held by hard references. Non change tracked objects will always
     * be held by “hard” references and are not available for GC. This is the
     * default mode for EclipsLink. See:
     * {@link java.lang.ref.WeakReference}
     * {@link org.eclipse.persistence.descriptors.changetracking.AttributeChangeTrackingPolicy}
     */
    WEAK,
 
    /**
     * Same as weak reference except Objects that can not be changed
     * tracked (Deferred Change Detection) will not be prevented from being
     * garbage collected.  This may result in a loss of changes if a changed object
     * is removed before being flushed to the database.
     * When a change is made to a change tracked object that object
     * is moved to a hard reference and will not be available for GC until
     * flushed. New and removed objects are also held by hard references until
     * flush.. 
     */
    FORCE_WEAK
}

A particular EM/UnitOfWork mode is configured through the acquireUnitOfWork API or through the Entity Manager property "eclipselink.persistence.context.reference-mode" during the createEntityManager(Map) call. The PersistenceUnit/Session wide default can be set through the Session.setDefaultReferenceMode() or "eclipselink.persistence.context.reference-mode.default".

Design

This functionality is achieved by altering two sections of the UnitOfWork. When users have selected the WEAK or FORCED_WEAK mode the cloneMapping IdentityHashMap will be switched out for the new WeakIdentityHashMap . This new Map supports keys being garbage collected. The second part is extending the current UnitOfWorkIdentity map to support weak references in the same manner as the WeakIdentityMap. If the reference mode is WEAK then any class that supports ChangeTracking will have a WeakUnitOfWorkIdentityMap with FORCE_WEAK all classes will use this extended IdentityMap. This IdentityMap class contains the same optimizations as the UnitOfWorkIdentityMap.

The only interesting design item is the use of a ReferenceQueue to improve the performance of cleaning up the dead references. As a WeakReference is created it is associated with a ReferenceQueue. As the garbage collector processes the weak references the collected references are added to this queue. Then within the Map's cleanup code the queue is polled for dead references to be removed from the Maps. This ensures only those references that are actually GC'd will need to be processed instead of the entire list as we currently do. This process may improve our current performance with Weak Identity Maps.

Open Issues

This section lists the open issues that are still pending that must be decided prior to fully implementing this project's requirements.

Issue # Owner Description / Notes

Decisions

This section lists decisions made. These are intended to document the resolution of open issues or constraints added to the project that are important.

Issue # Description / Notes Decision

Future Considerations

Author Description
Mike Keith A dynamic API to set this option on an EM. This would be nice for those extended PC EMs that one gets from SFSB...

Copyright © Eclipse Foundation, Inc. All Rights Reserved.