public class ConnectionPool extends Object
PoolProperties object for storing all the meta information about the connection pool.
 As the underlying implementation, the connection pool uses BlockingQueue to store active and idle connections.
 A custom implementation of a fair FairBlockingQueue blocking queue is provided with the connection pool itself.| Modifier and Type | Class and Description | 
|---|---|
| protected class  | ConnectionPool.ConnectionFutureTread safe wrapper around a future for the regular queue
 This one retrieves the pooled connection object
 and performs the initialization according to
 interceptors and validation rules. | 
| protected static class  | ConnectionPool.PoolCleaner | 
| Modifier and Type | Field and Description | 
|---|---|
| protected ConnectionPool | jmxPoolreference to the JMX mbean | 
| static String | POOL_JMX_DOMAINDefault domain for objects registering with an mbean server | 
| static String | POOL_JMX_TYPE_PREFIXPrefix type for JMX registration | 
| Constructor and Description | 
|---|
| ConnectionPool(PoolConfiguration prop)Instantiate a connection pool. | 
| Modifier and Type | Method and Description | 
|---|---|
| protected void | abandon(PooledConnection con)thread safe way to abandon a connection
 signals a connection to be abandoned. | 
| protected PooledConnection | borrowConnection(long now,
                PooledConnection con,
                String username,
                String password)Validates and configures a previously idle connection | 
| void | checkAbandoned()Iterates through all the busy connections and checks for connections that have timed out | 
| void | checkIdle()Iterates through the idle connections and resizes the idle pool based on parameters
  PoolProperties.maxIdle,PoolProperties.minIdle,PoolProperties.minEvictableIdleTimeMillis | 
| void | checkIdle(boolean ignoreMinSize) | 
| void | checkPoolConfiguration(PoolConfiguration properties) | 
| protected void | close(boolean force)Closes the pool and all disconnects all idle connections
 Active connections will be closed upon the  closemethod is called
 on the underlying connection instead of being returned to the pool | 
| protected PooledConnection | create(boolean incrementCounter)Create a new pooled connection object. | 
| protected PooledConnection | createConnection(long now,
                PooledConnection notUsed,
                String username,
                String password)Creates a JDBC connection and tries to connect to the database. | 
| protected void | createMBean()Create MBean object that can be registered. | 
| protected void | disconnectEvent(PooledConnection con,
               boolean finalizing)Hook to perform final actions on a pooled connection object once it has been disconnected and will be discarded | 
| protected void | finalize(PooledConnection con)Hook to perform final actions on a pooled connection object once it has been disconnected and will be discarded | 
| int | getActive()Returns the number of connections that are in use | 
| long | getBorrowedCount()The total number of connections borrowed from this pool. | 
| Connection | getConnection()Borrows a connection from the pool. | 
| Connection | getConnection(String username,
             String password)Borrows a connection from the pool. | 
| Future<Connection> | getConnectionAsync()Retrieves a Connection future. | 
| long | getCreatedCount()The total number of connections created by this pool. | 
| int | getIdle()Returns the number of idle connections | 
| ConnectionPool | getJmxPool()Return the object that is potentially registered in JMX for notifications | 
| String | getName()Returns the name of this pool | 
| static Set<TimerTask> | getPoolCleaners() | 
| PoolConfiguration | getPoolProperties()Returns the pool properties associated with this connection pool | 
| static Timer | getPoolTimer() | 
| long | getPoolVersion() | 
| Constructor<?> | getProxyConstructor(boolean xa)Creates and caches a  Constructorused to instantiate the proxy object. | 
| long | getReconnectedCount()The total number of connections reconnected by this pool. | 
| long | getReleasedCount()The total number of connections released from this pool. | 
| long | getReleasedIdleCount()The total number of connections released by eviction. | 
| long | getRemoveAbandonedCount()The total number of connections released by remove abandoned. | 
| long | getReturnedCount()The total number of connections returned to this pool. | 
| int | getSize()Returns the total size of this pool, this includes both busy and idle connections | 
| static String | getStackTrace(Throwable x)Convert an exception into a String | 
| protected static String | getThreadDump()Creates a stack trace representing the existing thread's current state. | 
| int | getWaitCount()Return the number of threads waiting for a connection | 
| protected void | init(PoolConfiguration properties)Initialize the connection pool - called from the constructor | 
| void | initializePoolCleaner(PoolConfiguration properties) | 
| boolean | isClosed()Returns true if  closehas been called, and the connection pool is unusable | 
| void | purge()Purges all connections in the pool. | 
| void | purgeOnReturn()Purges connections when they are returned from the pool. | 
| protected boolean | reconnectIfExpired(PooledConnection con)Checks whether this connection has  expiredand tries to reconnect if it has. | 
| protected void | release(PooledConnection con)thread safe way to release a connection | 
| void | resetStats()reset the statistics of this pool. | 
| protected void | returnConnection(PooledConnection con)Returns a connection to the pool
 If the pool is closed, the connection will be released
 If the connection is not part of the busy queue, it will be released. | 
| protected Connection | setupConnection(PooledConnection con)configures a pooled connection as a proxy. | 
| protected boolean | shouldAbandon()Determines if a connection should be abandoned based on
  PoolProperties.abandonWhenPercentageFullsetting. | 
| protected boolean | shouldClose(PooledConnection con,
           int action)Determines if a connection should be closed upon return to the pool. | 
| protected boolean | shouldReleaseIdle(long now,
                 PooledConnection con,
                 long time) | 
| protected void | suspect(PooledConnection con)Thread safe way to suspect a connection. | 
| void | terminatePoolCleaner() | 
| protected boolean | terminateTransaction(PooledConnection con)Terminate the current transaction for the given connection. | 
| void | testAllIdle()Forces a validation of all idle connections if  PoolProperties.testWhileIdleis set. | 
| void | testAllIdle(boolean checkMaxAgeOnly)Forces a validation of all idle connections if  PoolProperties.testWhileIdleis set. | 
public static final String POOL_JMX_DOMAIN
public static final String POOL_JMX_TYPE_PREFIX
protected ConnectionPool jmxPool
public ConnectionPool(PoolConfiguration prop) throws SQLException
PoolProperties should not be reused for another connection pool.prop - PoolProperties - all the properties for this connection poolSQLException - Pool initialization errorpublic Future<Connection> getConnectionAsync() throws SQLException
SQLException - Cannot use asynchronous connectpublic Connection getConnection() throws SQLException
maxActive connections a connection is returned immediately.
 If no connection is available, the pool will attempt to fetch a connection for maxWait milliseconds.SQLException - - if the wait times out or a failure occurs creating a connectionpublic Connection getConnection(String username, String password) throws SQLException
maxActive connections a connection is returned immediately. If no
 connection is available, the pool will attempt to fetch a connection for
 maxWait milliseconds.username - The user name to use for the connectionpassword - The password for the connectionSQLException - - if the wait times out or a failure occurs creating a
             connectionpublic String getName()
public int getWaitCount()
public PoolConfiguration getPoolProperties()
public int getSize()
public int getActive()
public int getIdle()
public boolean isClosed()
close has been called, and the connection pool is unusableprotected Connection setupConnection(PooledConnection con) throws SQLException
Connection and PooledConnection interfaces.
 All calls on Connection methods will be propagated down to the actual JDBC connection except for the
 Connection.close() method.con - a PooledConnection to wrap in a ProxyConnection object wrapping a pooled connection.SQLException - if an interceptor can't be configured, if the proxy can't be instantiatedpublic Constructor<?> getProxyConstructor(boolean xa) throws NoSuchMethodException
Constructor used to instantiate the proxy object.
 We cache this, since the creation of a constructor is fairly slow.xa - Use a XA connectionNoSuchMethodException - Failed to get a constructorprotected void close(boolean force)
close method is called
 on the underlying connection instead of being returned to the poolforce - - true to even close the active connectionsprotected void init(PoolConfiguration properties) throws SQLException
properties - PoolProperties - properties used to initialize the pool withSQLException - if initialization failspublic void checkPoolConfiguration(PoolConfiguration properties)
public void initializePoolCleaner(PoolConfiguration properties)
public void terminatePoolCleaner()
protected void abandon(PooledConnection con)
con - PooledConnectionprotected void suspect(PooledConnection con)
abandon(PooledConnection), but instead of actually abandoning
 the connection, this will log a warning and set the suspect flag on the
 PooledConnection if logAbandoned=truecon - PooledConnectionprotected void release(PooledConnection con)
con - PooledConnectionprotected PooledConnection createConnection(long now, PooledConnection notUsed, String username, String password) throws SQLException
now - timestamp of when this was callednotUsed - Argument not usedusername - The user name to use for the connectionpassword - The password for the connectionSQLException - Failed to get a connectionprotected PooledConnection borrowConnection(long now, PooledConnection con, String username, String password) throws SQLException
now - - timestampcon - - the connection to validate and configureusername - The user name to use for the connectionpassword - The password for the connectionSQLException - if a validation error happensprotected boolean terminateTransaction(PooledConnection con)
con - The connectiontrue if the connection TX termination succeeded
         otherwise falseprotected boolean shouldClose(PooledConnection con, int action)
con - - the connectionaction - - the validation action that should be performedtrue if the connection should be closedprotected boolean reconnectIfExpired(PooledConnection con)
expired and tries to reconnect if it has.con - PooledConnectionPooledConnection.isMaxAgeExpired()protected void returnConnection(PooledConnection con)
PoolProperties.testOnReturn is set to true it will be validatedcon - PooledConnection to be returned to the poolprotected boolean shouldAbandon()
PoolProperties.abandonWhenPercentageFull setting.true if the connection should be abandonedpublic void checkAbandoned()
public void checkIdle()
PoolProperties.maxIdle, PoolProperties.minIdle, PoolProperties.minEvictableIdleTimeMillispublic void checkIdle(boolean ignoreMinSize)
protected boolean shouldReleaseIdle(long now,
                                    PooledConnection con,
                                    long time)
public void testAllIdle()
PoolProperties.testWhileIdle is set.public void testAllIdle(boolean checkMaxAgeOnly)
PoolProperties.testWhileIdle is set.checkMaxAgeOnly - whether to only check PooledConnection.isMaxAgeExpired() but
                        not invoke PooledConnection.validate(int)protected static String getThreadDump()
Thread.getStackTrace() elementspublic static String getStackTrace(Throwable x)
x - - the throwableprotected PooledConnection create(boolean incrementCounter)
incrementCounter - true to increment the connection countpublic void purge()
purgeOnReturn()public void purgeOnReturn()
purge()protected void finalize(PooledConnection con)
con - The connectionprotected void disconnectEvent(PooledConnection con, boolean finalizing)
con - The connectionfinalizing - true if finalizing the connectionpublic ConnectionPool getJmxPool()
ConnectionPoolMBean interfaceprotected void createMBean()
public long getBorrowedCount()
public long getReturnedCount()
public long getCreatedCount()
public long getReleasedCount()
public long getReconnectedCount()
public long getRemoveAbandonedCount()
public long getReleasedIdleCount()
public void resetStats()
public long getPoolVersion()
public static Timer getPoolTimer()
Copyright © 2000-2021 Apache Software Foundation. All Rights Reserved.