mirror of https://github.com/apache/openjpa.git
Merge from ../active. svn merge -c 653000 ../active
git-svn-id: https://svn.apache.org/repos/asf/openjpa/trunk@666900 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
547438ed18
commit
e8702b1ed3
|
@ -52,16 +52,32 @@ public class BrokerValue
|
||||||
|
|
||||||
public Object newInstance(String clsName, Class type, Configuration conf,
|
public Object newInstance(String clsName, Class type, Configuration conf,
|
||||||
boolean fatal) {
|
boolean fatal) {
|
||||||
// This is not synchronized. If there are concurrent invocations
|
getTemplateBroker(clsName, type, conf, fatal);
|
||||||
// while _templateBroker is null, we'll just end up with extra
|
|
||||||
// template brokers, which will get safely garbage collected.
|
|
||||||
if (_templateBroker == null)
|
|
||||||
_templateBroker = (BrokerImpl) super.newInstance(clsName, type,
|
|
||||||
conf, fatal);
|
|
||||||
try {
|
try {
|
||||||
return _templateBroker.clone();
|
return _templateBroker.clone();
|
||||||
} catch (CloneNotSupportedException e) {
|
} catch (CloneNotSupportedException e) {
|
||||||
throw new InternalException(e);
|
throw new InternalException(e);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public Class<? extends BrokerImpl> getTemplateBrokerType(Configuration c) {
|
||||||
|
return getTemplateBroker(getClassName(), BrokerImpl.class, c, true)
|
||||||
|
.getClass();
|
||||||
|
}
|
||||||
|
|
||||||
|
private BrokerImpl getTemplateBroker(String clsName, Class type,
|
||||||
|
Configuration conf, boolean fatal) {
|
||||||
|
if (clsName == null || !clsName.equals(getClassName()))
|
||||||
|
throw new IllegalArgumentException("clsName != configured value '"
|
||||||
|
+ getClassName() + "'");
|
||||||
|
|
||||||
|
// This is not synchronized. If there are concurrent invocations
|
||||||
|
// while _templateBroker is null, we'll just end up with extra
|
||||||
|
// template brokers, which will get safely garbage collected.
|
||||||
|
if (_templateBroker == null)
|
||||||
|
_templateBroker = (BrokerImpl) super.newInstance(clsName, type,
|
||||||
|
conf, fatal);
|
||||||
|
return _templateBroker;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -76,7 +76,7 @@ public class OpenJPAConfigurationImpl
|
||||||
|
|
||||||
// openjpa properties
|
// openjpa properties
|
||||||
public ObjectValue classResolverPlugin;
|
public ObjectValue classResolverPlugin;
|
||||||
public ObjectValue brokerPlugin;
|
public BrokerValue brokerPlugin;
|
||||||
public ObjectValue dataCachePlugin;
|
public ObjectValue dataCachePlugin;
|
||||||
public ObjectValue dataCacheManagerPlugin;
|
public ObjectValue dataCacheManagerPlugin;
|
||||||
public IntValue dataCacheTimeout;
|
public IntValue dataCacheTimeout;
|
||||||
|
|
|
@ -19,7 +19,6 @@
|
||||||
package org.apache.openjpa.kernel;
|
package org.apache.openjpa.kernel;
|
||||||
|
|
||||||
import java.io.ObjectStreamException;
|
import java.io.ObjectStreamException;
|
||||||
import java.lang.reflect.InvocationTargetException;
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Collection;
|
import java.util.Collection;
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
|
@ -29,14 +28,18 @@ import java.util.LinkedList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.Properties;
|
import java.util.Properties;
|
||||||
|
import java.util.Set;
|
||||||
import javax.transaction.Status;
|
import javax.transaction.Status;
|
||||||
import javax.transaction.Synchronization;
|
import javax.transaction.Synchronization;
|
||||||
import javax.transaction.Transaction;
|
import javax.transaction.Transaction;
|
||||||
import javax.transaction.TransactionManager;
|
import javax.transaction.TransactionManager;
|
||||||
|
|
||||||
import org.apache.commons.lang.StringUtils;
|
import org.apache.commons.lang.StringUtils;
|
||||||
|
import org.apache.commons.collections.set.MapBackedSet;
|
||||||
import org.apache.openjpa.conf.OpenJPAConfiguration;
|
import org.apache.openjpa.conf.OpenJPAConfiguration;
|
||||||
import org.apache.openjpa.conf.OpenJPAVersion;
|
import org.apache.openjpa.conf.OpenJPAVersion;
|
||||||
|
import org.apache.openjpa.conf.BrokerValue;
|
||||||
|
import org.apache.openjpa.conf.OpenJPAConfigurationImpl;
|
||||||
import org.apache.openjpa.datacache.DataCacheStoreManager;
|
import org.apache.openjpa.datacache.DataCacheStoreManager;
|
||||||
import org.apache.openjpa.ee.ManagedRuntime;
|
import org.apache.openjpa.ee.ManagedRuntime;
|
||||||
import org.apache.openjpa.enhance.PCRegistry;
|
import org.apache.openjpa.enhance.PCRegistry;
|
||||||
|
@ -48,14 +51,12 @@ import org.apache.openjpa.lib.conf.Configuration;
|
||||||
import org.apache.openjpa.lib.conf.Configurations;
|
import org.apache.openjpa.lib.conf.Configurations;
|
||||||
import org.apache.openjpa.lib.log.Log;
|
import org.apache.openjpa.lib.log.Log;
|
||||||
import org.apache.openjpa.lib.util.J2DoPrivHelper;
|
import org.apache.openjpa.lib.util.J2DoPrivHelper;
|
||||||
import org.apache.openjpa.lib.util.JavaVersions;
|
|
||||||
import org.apache.openjpa.lib.util.Localizer;
|
import org.apache.openjpa.lib.util.Localizer;
|
||||||
import java.util.concurrent.ConcurrentHashMap;
|
import java.util.concurrent.ConcurrentHashMap;
|
||||||
import org.apache.openjpa.lib.util.concurrent.ConcurrentReferenceHashSet;
|
import org.apache.openjpa.lib.util.concurrent.ConcurrentReferenceHashSet;
|
||||||
import java.util.concurrent.locks.ReentrantLock;
|
import java.util.concurrent.locks.ReentrantLock;
|
||||||
import org.apache.openjpa.meta.MetaDataRepository;
|
import org.apache.openjpa.meta.MetaDataRepository;
|
||||||
import org.apache.openjpa.util.GeneralException;
|
import org.apache.openjpa.util.GeneralException;
|
||||||
import org.apache.openjpa.util.InternalException;
|
|
||||||
import org.apache.openjpa.util.InvalidStateException;
|
import org.apache.openjpa.util.InvalidStateException;
|
||||||
import org.apache.openjpa.util.OpenJPAException;
|
import org.apache.openjpa.util.OpenJPAException;
|
||||||
import org.apache.openjpa.util.UserException;
|
import org.apache.openjpa.util.UserException;
|
||||||
|
@ -90,8 +91,7 @@ public abstract class AbstractBrokerFactory
|
||||||
= new ConcurrentHashMap();
|
= new ConcurrentHashMap();
|
||||||
|
|
||||||
// weak-ref tracking of open brokers
|
// weak-ref tracking of open brokers
|
||||||
private transient Collection _brokers = new ConcurrentReferenceHashSet
|
private transient Set _brokers;
|
||||||
(ConcurrentReferenceHashSet.WEAK);
|
|
||||||
|
|
||||||
// cache the class names loaded from the persistent classes property so
|
// cache the class names loaded from the persistent classes property so
|
||||||
// that we can re-load them for each new broker
|
// that we can re-load them for each new broker
|
||||||
|
@ -145,6 +145,7 @@ public abstract class AbstractBrokerFactory
|
||||||
*/
|
*/
|
||||||
protected AbstractBrokerFactory(OpenJPAConfiguration config) {
|
protected AbstractBrokerFactory(OpenJPAConfiguration config) {
|
||||||
_conf = config;
|
_conf = config;
|
||||||
|
_brokers = newBrokerSet();
|
||||||
getPcClassLoaders();
|
getPcClassLoaders();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -384,7 +385,7 @@ public abstract class AbstractBrokerFactory
|
||||||
Broker broker;
|
Broker broker;
|
||||||
for (Iterator itr = _brokers.iterator(); itr.hasNext();) {
|
for (Iterator itr = _brokers.iterator(); itr.hasNext();) {
|
||||||
broker = (Broker) itr.next();
|
broker = (Broker) itr.next();
|
||||||
// Check for null because _brokers contains weak references
|
// Check for null because _brokers may contain weak references
|
||||||
if ((broker != null) && (!broker.isClosed()))
|
if ((broker != null) && (!broker.isClosed()))
|
||||||
broker.close();
|
broker.close();
|
||||||
}
|
}
|
||||||
|
@ -464,13 +465,29 @@ public abstract class AbstractBrokerFactory
|
||||||
|
|
||||||
// reset these transient fields to empty values
|
// reset these transient fields to empty values
|
||||||
_transactional = new ConcurrentHashMap();
|
_transactional = new ConcurrentHashMap();
|
||||||
_brokers = new ConcurrentReferenceHashSet(
|
_brokers = newBrokerSet();
|
||||||
ConcurrentReferenceHashSet.WEAK);
|
|
||||||
|
|
||||||
makeReadOnly();
|
makeReadOnly();
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private Set newBrokerSet() {
|
||||||
|
BrokerValue bv;
|
||||||
|
if (_conf instanceof OpenJPAConfigurationImpl)
|
||||||
|
bv = ((OpenJPAConfigurationImpl) _conf).brokerPlugin;
|
||||||
|
else
|
||||||
|
bv = (BrokerValue) _conf.getValue(BrokerValue.KEY);
|
||||||
|
|
||||||
|
if (FinalizingBrokerImpl.class.isAssignableFrom(
|
||||||
|
bv.getTemplateBrokerType(_conf))) {
|
||||||
|
return MapBackedSet.decorate(new ConcurrentHashMap(),
|
||||||
|
new Object() { });
|
||||||
|
} else {
|
||||||
|
return new ConcurrentReferenceHashSet(
|
||||||
|
ConcurrentReferenceHashSet.WEAK);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
////////////////////////
|
////////////////////////
|
||||||
// Methods for Override
|
// Methods for Override
|
||||||
////////////////////////
|
////////////////////////
|
||||||
|
@ -746,6 +763,16 @@ public abstract class AbstractBrokerFactory
|
||||||
return Collections.unmodifiableCollection(_brokers);
|
return Collections.unmodifiableCollection(_brokers);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Release <code>broker</code> from any internal data structures. This
|
||||||
|
* is invoked by <code>broker</code> after the broker is fully closed.
|
||||||
|
*
|
||||||
|
* @since 1.1.0
|
||||||
|
*/
|
||||||
|
protected void releaseBroker(BrokerImpl broker) {
|
||||||
|
_brokers.remove(broker);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @return a key that can be used to obtain this broker factory from the
|
* @return a key that can be used to obtain this broker factory from the
|
||||||
* pool at a later time.
|
* pool at a later time.
|
||||||
|
|
|
@ -4099,6 +4099,8 @@ public class BrokerImpl
|
||||||
if (_log.isTraceEnabled())
|
if (_log.isTraceEnabled())
|
||||||
_closedException = new IllegalStateException();
|
_closedException = new IllegalStateException();
|
||||||
|
|
||||||
|
_factory.releaseBroker(this);
|
||||||
|
|
||||||
if (err != null)
|
if (err != null)
|
||||||
throw err;
|
throw err;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue