| 
 | ||||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||
java.lang.Objectorg.springframework.aop.target.AbstractBeanFactoryBasedTargetSource
org.springframework.aop.target.AbstractPrototypeBasedTargetSource
org.springframework.aop.target.AbstractPoolingTargetSource
org.springframework.aop.target.CommonsPoolTargetSource
public class CommonsPoolTargetSource
TargetSource implementation that holds objects in a configurable Jakarta Commons Pool.
By default, an instance of GenericObjectPool is created.
 Subclasses may change the type of ObjectPool used by
 overriding the createObjectPool() method.
 
Provides many configuration properties mirroring those of the Commons Pool
 GenericObjectPool class; these properties are passed to the
 GenericObjectPool during construction. If creating a subclass of this
 class to change the ObjectPool implementation type, pass in the values
 of configuration properties that are relevant to your chosen implementation.
 
The testOnBorrow, testOnReturn and testWhileIdle
 properties are explictly not mirrored because the implementation of
 PoolableObjectFactory used by this class does not implement
 meaningful validation. All exposed Commons Pool properties use the corresponding
 Commons Pool defaults: for example,
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 | |
|---|---|
| CommonsPoolTargetSource()Create a CommonsPoolTargetSource with default settings. | |
| Method Summary | |
|---|---|
|  void | activateObject(Object o) | 
| protected  ObjectPool | createObjectPool()Subclasses can override this if they want to return a specific Commons pool. | 
| protected  void | createPool(BeanFactory beanFactory)Creates and holds an ObjectPool instance. | 
|  void | destroy()Closes the underlying ObjectPoolwhen destroying this object. | 
|  void | destroyObject(Object o) | 
|  int | getActiveCount()Return the number of active objects in the pool. | 
|  int | getIdleCount()Return the number of idle objects in the pool. | 
|  int | getMaxIdle()Return the maximum number of idle objects in the pool. | 
|  long | getMaxWait()Return the maximum waiting time for fetching an object from the pool. | 
|  long | getMinEvictableIdleTimeMillis()Return the minimum time that an idle object can sit in the pool. | 
|  int | getMinIdle()Return the minimum number of idle objects in the pool. | 
|  Object | getTarget()Borrow an object from the ObjectPool. | 
|  long | getTimeBetweenEvictionRunsMillis()Return the time between eviction runs that check idle objects. | 
|  byte | getWhenExhaustedAction()Return the action to take when the pool is exhausted. | 
|  Object | makeObject() | 
|  void | passivateObject(Object o) | 
|  void | releaseTarget(Object target)Returns the specified object to the underlying ObjectPool. | 
|  void | setMaxIdle(int maxIdle)Set the maximum number of idle objects in the pool. | 
|  void | setMaxWait(long maxWait)Set the maximum waiting time for fetching an object from the pool. | 
|  void | setMinEvictableIdleTimeMillis(long minEvictableIdleTimeMillis)Set the minimum time that an idle object can sit in the pool before it becomes subject to eviction. | 
|  void | setMinIdle(int minIdle)Set the minimum number of idle objects in the pool. | 
|  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. | 
|  void | setWhenExhaustedAction(byte whenExhaustedAction)Set the action to take when the pool is exhausted. | 
|  void | setWhenExhaustedActionName(String whenExhaustedActionName)Set the action to take when the pool is exhausted. | 
|  boolean | validateObject(Object o) | 
| Methods inherited from class org.springframework.aop.target.AbstractPoolingTargetSource | 
|---|
| getMaxSize, getPoolingConfigMixin, setBeanFactory, setMaxSize | 
| Methods inherited from class org.springframework.aop.target.AbstractPrototypeBasedTargetSource | 
|---|
| newPrototypeInstance | 
| Methods inherited from class org.springframework.aop.target.AbstractBeanFactoryBasedTargetSource | 
|---|
| copyFrom, getBeanFactory, getTargetBeanName, getTargetClass, isStatic, setTargetBeanName, setTargetClass, toString, writeReplace | 
| Methods inherited from class java.lang.Object | 
|---|
| clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait | 
| Constructor Detail | 
|---|
public CommonsPoolTargetSource()
AbstractPoolingTargetSource.setMaxSize(int), 
GenericObjectPool.setMaxActive(int)| Method Detail | 
|---|
public void setMaxIdle(int maxIdle)
GenericObjectPool.setMaxIdle(int)public int getMaxIdle()
public void setMinIdle(int minIdle)
GenericObjectPool.setMinIdle(int)public int getMinIdle()
public void setMaxWait(long maxWait)
GenericObjectPool.setMaxWait(long)public long getMaxWait()
public void setTimeBetweenEvictionRunsMillis(long timeBetweenEvictionRunsMillis)
GenericObjectPool.setTimeBetweenEvictionRunsMillis(long)public long getTimeBetweenEvictionRunsMillis()
public void setMinEvictableIdleTimeMillis(long minEvictableIdleTimeMillis)
Note that eviction runs need to be performed to take this setting into effect.
setTimeBetweenEvictionRunsMillis(long), 
GenericObjectPool.setMinEvictableIdleTimeMillis(long)public long getMinEvictableIdleTimeMillis()
public void setWhenExhaustedActionName(String whenExhaustedActionName)
setWhenExhaustedAction(byte)public void setWhenExhaustedAction(byte whenExhaustedAction)
GenericObjectPool.setWhenExhaustedAction(byte), 
GenericObjectPool.WHEN_EXHAUSTED_BLOCK, 
GenericObjectPool.WHEN_EXHAUSTED_FAIL, 
GenericObjectPool.WHEN_EXHAUSTED_GROWpublic byte getWhenExhaustedAction()
protected final void createPool(BeanFactory beanFactory)
createPool in class AbstractPoolingTargetSourcebeanFactory - owning BeanFactory, in case we need collaborators from it
 (normally our own properties are sufficient)createObjectPool()protected ObjectPool createObjectPool()
Default is a GenericObjectPool instance with the given pool size.
ObjectPool.GenericObjectPool, 
AbstractPoolingTargetSource.setMaxSize(int)
public Object getTarget()
                 throws Exception
ObjectPool.
getTarget in interface TargetSourcegetTarget in class AbstractPoolingTargetSourceException - we may need to deal with checked exceptions from pool
 APIs, so we're forgiving with our exception signature
public void releaseTarget(Object target)
                   throws Exception
ObjectPool.
releaseTarget in interface TargetSourcereleaseTarget in class AbstractPoolingTargetSourcetarget - object that must have been acquired from the pool
 via a call to getTarget()
Exception - to allow pooling APIs to throw exceptionAbstractPoolingTargetSource.getTarget()
public int getActiveCount()
                   throws UnsupportedOperationException
PoolingConfig
getActiveCount in interface PoolingConfigUnsupportedOperationException - if not supported by the pool
public int getIdleCount()
                 throws UnsupportedOperationException
PoolingConfig
getIdleCount in interface PoolingConfigUnsupportedOperationException - if not supported by the pool
public void destroy()
             throws Exception
ObjectPool when destroying this object.
destroy in interface DisposableBeanException - in case of shutdown errors.
 Exceptions will get logged but not rethrown to allow
 other beans to release their resources too.
public Object makeObject()
                  throws BeansException
makeObject in interface PoolableObjectFactoryBeansException
public void destroyObject(Object o)
                   throws Exception
destroyObject in interface PoolableObjectFactoryExceptionpublic boolean validateObject(Object o)
validateObject in interface PoolableObjectFactory
public void activateObject(Object o)
                    throws Exception
activateObject in interface PoolableObjectFactoryException
public void passivateObject(Object o)
                     throws Exception
passivateObject in interface PoolableObjectFactoryException| 
 | ||||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||