Class CommonsPool2TargetSource
- java.lang.Object
- org.springframework.aop.target.AbstractBeanFactoryBasedTargetSource
- org.springframework.aop.target.AbstractPrototypeBasedTargetSource
- org.springframework.aop.target.AbstractPoolingTargetSource
- org.springframework.aop.target.CommonsPool2TargetSource
- All Implemented Interfaces:
Serializable,org.apache.commons.pool2.PooledObjectFactory<Object>,PoolingConfig,TargetClassAware,TargetSource,Aware,BeanFactoryAware,DisposableBean
public class CommonsPool2TargetSource extends AbstractPoolingTargetSource implements org.apache.commons.pool2.PooledObjectFactory<Object>
TargetSourceimplementation that holds objects in a configurable Apache Commons2 Pool.By default, an instance of
GenericObjectPoolis created. Subclasses may change the type ofObjectPoolused by overriding thecreateObjectPool()method.Provides many configuration properties mirroring those of the Commons Pool
GenericObjectPoolclass; these properties are passed to theGenericObjectPoolduring construction. If creating a subclass of this class to change theObjectPoolimplementation type, pass in the values of configuration properties that are relevant to your chosen implementation.The
testOnBorrow,testOnReturnandtestWhileIdleproperties are explicitly not mirrored because the implementation ofPoolableObjectFactoryused by this class does not implement meaningful validation. All exposed Commons Pool properties use the corresponding Commons Pool defaults.Compatible with Apache Commons Pool 2.4, as of Spring 4.2.
- Since:
- 4.2
- Author:
- Rod Johnson, Rob Harrop, Juergen Hoeller, Stephane Nicoll, Kazuki Shimizu
- See Also:
GenericObjectPool,createObjectPool(),AbstractPoolingTargetSource.setMaxSize(int),setMaxIdle(int),setMinIdle(int),setMaxWait(long),setTimeBetweenEvictionRunsMillis(long),setMinEvictableIdleTimeMillis(long), Serialized Form
Field Summary
Fields inherited from class org.springframework.aop.target.AbstractBeanFactoryBasedTargetSource
logger
Constructor Summary
Constructors Constructor Description CommonsPool2TargetSource()Create a CommonsPoolTargetSource with default settings.
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description voidactivateObject(org.apache.commons.pool2.PooledObject<Object> p)protected org.apache.commons.pool2.ObjectPoolcreateObjectPool()Subclasses can override this if they want to return a specific Commons pool.protected voidcreatePool()Creates and holds an ObjectPool instance.voiddestroy()Closes the underlyingObjectPoolwhen destroying this object.voiddestroyObject(org.apache.commons.pool2.PooledObject<Object> p)intgetActiveCount()Return the number of active objects in the pool.intgetIdleCount()Return the number of idle objects in the pool.intgetMaxIdle()Return the maximum number of idle objects in the pool.longgetMaxWait()Return the maximum waiting time for fetching an object from the pool.longgetMinEvictableIdleTimeMillis()Return the minimum time that an idle object can sit in the pool.intgetMinIdle()Return the minimum number of idle objects in the pool.ObjectgetTarget()Borrows an object from theObjectPool.longgetTimeBetweenEvictionRunsMillis()Return the time between eviction runs that check idle objects.booleanisBlockWhenExhausted()Specify if the call should block when the pool is exhausted.org.apache.commons.pool2.PooledObject<Object>makeObject()voidpassivateObject(org.apache.commons.pool2.PooledObject<Object> p)voidreleaseTarget(Object target)Returns the specified object to the underlyingObjectPool.voidsetBlockWhenExhausted(boolean blockWhenExhausted)Set whether the call should bock when the pool is exhausted.voidsetMaxIdle(int maxIdle)Set the maximum number of idle objects in the pool.voidsetMaxWait(long maxWait)Set the maximum waiting time for fetching an object from the pool.voidsetMinEvictableIdleTimeMillis(long minEvictableIdleTimeMillis)Set the minimum time that an idle object can sit in the pool before it becomes subject to eviction.voidsetMinIdle(int minIdle)Set the minimum number of idle objects in the pool.voidsetTimeBetweenEvictionRunsMillis(long timeBetweenEvictionRunsMillis)Set the time between eviction runs that check idle objects whether they have been idle for too long or have become invalid.booleanvalidateObject(org.apache.commons.pool2.PooledObject<Object> p)Methods inherited from class org.springframework.aop.target.AbstractPoolingTargetSource
getMaxSize, getPoolingConfigMixin, setBeanFactory, setMaxSize
Methods inherited from class org.springframework.aop.target.AbstractPrototypeBasedTargetSource
destroyPrototypeInstance, newPrototypeInstance, writeReplace
Methods inherited from class org.springframework.aop.target.AbstractBeanFactoryBasedTargetSource
copyFrom, equals, getBeanFactory, getTargetBeanName, getTargetClass, hashCode, isStatic, setTargetBeanName, setTargetClass, toString
Constructor Detail
CommonsPool2TargetSource
public CommonsPool2TargetSource()
Create a CommonsPoolTargetSource with default settings. Default maximum size of the pool is 8.- See Also:
AbstractPoolingTargetSource.setMaxSize(int),GenericObjectPoolConfig.setMaxTotal(int)
Method Detail
setMaxIdle
public void setMaxIdle(int maxIdle)
Set the maximum number of idle objects in the pool. Default is 8.- See Also:
GenericObjectPool.setMaxIdle(int)
getMaxIdle
public int getMaxIdle()
Return the maximum number of idle objects in the pool.
setMinIdle
public void setMinIdle(int minIdle)
Set the minimum number of idle objects in the pool. Default is 0.- See Also:
GenericObjectPool.setMinIdle(int)
getMinIdle
public int getMinIdle()
Return the minimum number of idle objects in the pool.
setMaxWait
public void setMaxWait(long maxWait)
Set the maximum waiting time for fetching an object from the pool. Default is -1, waiting forever.- See Also:
BaseGenericObjectPool.setMaxWaitMillis(long)
getMaxWait
public long getMaxWait()
Return the maximum waiting time for fetching an object from the pool.
setTimeBetweenEvictionRunsMillis
public void setTimeBetweenEvictionRunsMillis(long timeBetweenEvictionRunsMillis)
Set the time between eviction runs that check idle objects whether they have been idle for too long or have become invalid. Default is -1, not performing any eviction.- See Also:
BaseGenericObjectPool.setTimeBetweenEvictionRunsMillis(long)
getTimeBetweenEvictionRunsMillis
public long getTimeBetweenEvictionRunsMillis()
Return the time between eviction runs that check idle objects.
setMinEvictableIdleTimeMillis
public void setMinEvictableIdleTimeMillis(long minEvictableIdleTimeMillis)
Set the minimum time that an idle object can sit in the pool before it becomes subject to eviction. Default is 1800000 (30 minutes).Note that eviction runs need to be performed to take this setting into effect.
- See Also:
setTimeBetweenEvictionRunsMillis(long),BaseGenericObjectPool.setMinEvictableIdleTimeMillis(long)
getMinEvictableIdleTimeMillis
public long getMinEvictableIdleTimeMillis()
Return the minimum time that an idle object can sit in the pool.
setBlockWhenExhausted
public void setBlockWhenExhausted(boolean blockWhenExhausted)
Set whether the call should bock when the pool is exhausted.
isBlockWhenExhausted
public boolean isBlockWhenExhausted()
Specify if the call should block when the pool is exhausted.
createPool
protected final void createPool()
Creates and holds an ObjectPool instance.- Specified by:
createPoolin classAbstractPoolingTargetSource- See Also:
createObjectPool()
createObjectPool
protected org.apache.commons.pool2.ObjectPool createObjectPool()
Subclasses can override this if they want to return a specific Commons pool. They should apply any configuration properties to the pool here.Default is a GenericObjectPool instance with the given pool size.
- Returns:
- an empty Commons
ObjectPool. - See Also:
GenericObjectPool,AbstractPoolingTargetSource.setMaxSize(int)
getTarget
public Object getTarget() throws Exception
Borrows an object from theObjectPool.- Specified by:
getTargetin interfaceTargetSource- Specified by:
getTargetin classAbstractPoolingTargetSource- Returns:
- an object from the pool
- Throws:
Exception- we may need to deal with checked exceptions from pool APIs, so we're forgiving with our exception signature
releaseTarget
public void releaseTarget(Object target) throws Exception
Returns the specified object to the underlyingObjectPool.- Specified by:
releaseTargetin interfaceTargetSource- Specified by:
releaseTargetin classAbstractPoolingTargetSource- Parameters:
target- object that must have been acquired from the pool via a call togetTarget()- Throws:
Exception- to allow pooling APIs to throw exception- See Also:
AbstractPoolingTargetSource.getTarget()
getActiveCount
public int getActiveCount() throws UnsupportedOperationException
Description copied from interface:PoolingConfigReturn the number of active objects in the pool.- Specified by:
getActiveCountin interfacePoolingConfig- Throws:
UnsupportedOperationException- if not supported by the pool
getIdleCount
public int getIdleCount() throws UnsupportedOperationException
Description copied from interface:PoolingConfigReturn the number of idle objects in the pool.- Specified by:
getIdleCountin interfacePoolingConfig- Throws:
UnsupportedOperationException- if not supported by the pool
destroy
public void destroy() throws Exception
Closes the underlyingObjectPoolwhen destroying this object.- Specified by:
destroyin interfaceDisposableBean- Throws:
Exception- in case of shutdown errors. Exceptions will get logged but not rethrown to allow other beans to release their resources as well.
makeObject
public org.apache.commons.pool2.PooledObject<Object> makeObject() throws Exception
destroyObject
public void destroyObject(org.apache.commons.pool2.PooledObject<Object> p) throws Exception
validateObject
public boolean validateObject(org.apache.commons.pool2.PooledObject<Object> p)
- Specified by:
validateObjectin interfaceorg.apache.commons.pool2.PooledObjectFactory<Object>
activateObject
public void activateObject(org.apache.commons.pool2.PooledObject<Object> p) throws Exception
passivateObject
public void passivateObject(org.apache.commons.pool2.PooledObject<Object> p) throws Exception