Class Pool
- java.lang.Object
-
- org.mariadb.jdbc.internal.util.pool.Pool
-
-
Field Summary
Fields Modifier and Type Field Description private java.util.concurrent.ThreadPoolExecutorconnectionAppenderprivate java.util.concurrent.BlockingQueue<java.lang.Runnable>connectionAppenderQueueprivate longconnectionTimeprivate GlobalStateInfoglobalInfoprivate java.util.concurrent.LinkedBlockingDeque<MariaDbPooledConnection>idleConnectionsprivate static Loggerloggerprivate intmaxIdleTimeprivate Optionsoptionsprivate java.util.concurrent.atomic.AtomicIntegerpendingRequestNumberprivate static intPOOL_STATE_CLOSINGprivate static intPOOL_STATE_OKprivate java.util.concurrent.ScheduledThreadPoolExecutorpoolExecutorprivate java.util.concurrent.atomic.AtomicIntegerpoolStateprivate java.lang.StringpoolTagprivate java.util.concurrent.ScheduledFuturescheduledFutureprivate longtimeToConnectNanosprivate java.util.concurrent.atomic.AtomicIntegertotalConnectionprivate UrlParserurlParser
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description private voidaddConnection()Create new connection.private voidaddConnectionRequest()Add new connection if needed.voidclose()Close pool and underlying connections.private voidcloseAll(java.util.concurrent.ExecutorService connectionRemover, java.util.Collection<MariaDbPooledConnection> collection)private MariaDbPooledConnectioncreatePoolConnection(MariaDbConnection connection)booleanequals(java.lang.Object obj)private java.lang.StringgeneratePoolTag(int poolIndex)longgetActiveConnections()MariaDbConnectiongetConnection()Retrieve new connection.MariaDbConnectiongetConnection(java.lang.String username, java.lang.String password)Get new connection from pool if user and password correspond to pool.longgetConnectionRequests()GlobalStateInfogetGlobalInfo()private MariaDbPooledConnectiongetIdleConnection()private MariaDbPooledConnectiongetIdleConnection(long timeout, java.util.concurrent.TimeUnit timeUnit)Get an existing idle connection in pool.longgetIdleConnections()java.lang.StringgetPoolTag()longgetTotalConnections()UrlParsergetUrlParser()inthashCode()private voidinitializePoolGlobalState(MariaDbConnection connection)private voidregisterJmx()private voidremoveIdleTimeoutConnection()Removing idle connection.voidresetStaticGlobal()JMX method to remove state (will be reinitialized on next connection creation).private voidsilentAbortConnection(MariaDbPooledConnection item)private voidsilentCloseConnection(MariaDbPooledConnection item)java.util.List<java.lang.Long>testGetConnectionIdleThreadIds()For testing purpose only.private voidunRegisterJmx()
-
-
-
Field Detail
-
logger
private static final Logger logger
-
POOL_STATE_OK
private static final int POOL_STATE_OK
- See Also:
- Constant Field Values
-
POOL_STATE_CLOSING
private static final int POOL_STATE_CLOSING
- See Also:
- Constant Field Values
-
poolState
private final java.util.concurrent.atomic.AtomicInteger poolState
-
urlParser
private final UrlParser urlParser
-
options
private final Options options
-
pendingRequestNumber
private final java.util.concurrent.atomic.AtomicInteger pendingRequestNumber
-
totalConnection
private final java.util.concurrent.atomic.AtomicInteger totalConnection
-
idleConnections
private final java.util.concurrent.LinkedBlockingDeque<MariaDbPooledConnection> idleConnections
-
connectionAppender
private final java.util.concurrent.ThreadPoolExecutor connectionAppender
-
connectionAppenderQueue
private final java.util.concurrent.BlockingQueue<java.lang.Runnable> connectionAppenderQueue
-
poolTag
private final java.lang.String poolTag
-
poolExecutor
private final java.util.concurrent.ScheduledThreadPoolExecutor poolExecutor
-
scheduledFuture
private final java.util.concurrent.ScheduledFuture scheduledFuture
-
globalInfo
private GlobalStateInfo globalInfo
-
maxIdleTime
private int maxIdleTime
-
timeToConnectNanos
private long timeToConnectNanos
-
connectionTime
private long connectionTime
-
-
Constructor Detail
-
Pool
public Pool(UrlParser urlParser, int poolIndex, java.util.concurrent.ScheduledThreadPoolExecutor poolExecutor)
Create pool from configuration.- Parameters:
urlParser- configuration parserpoolIndex- pool index to permit distinction of thread namepoolExecutor- pools common executor
-
-
Method Detail
-
addConnectionRequest
private void addConnectionRequest()
Add new connection if needed. Only one thread create new connection, so new connection request will wait to newly created connection or for a released connection.
-
removeIdleTimeoutConnection
private void removeIdleTimeoutConnection()
Removing idle connection. Close them and recreate connection to reach minimal number of connection.
-
addConnection
private void addConnection() throws java.sql.SQLExceptionCreate new connection.- Throws:
java.sql.SQLException- if connection creation failed
-
getIdleConnection
private MariaDbPooledConnection getIdleConnection() throws java.lang.InterruptedException
- Throws:
java.lang.InterruptedException
-
getIdleConnection
private MariaDbPooledConnection getIdleConnection(long timeout, java.util.concurrent.TimeUnit timeUnit) throws java.lang.InterruptedException
Get an existing idle connection in pool.- Returns:
- an IDLE connection.
- Throws:
java.lang.InterruptedException
-
silentCloseConnection
private void silentCloseConnection(MariaDbPooledConnection item)
-
silentAbortConnection
private void silentAbortConnection(MariaDbPooledConnection item)
-
createPoolConnection
private MariaDbPooledConnection createPoolConnection(MariaDbConnection connection)
-
getConnection
public MariaDbConnection getConnection() throws java.sql.SQLException
Retrieve new connection. If possible return idle connection, if not, stack connection query, ask for a connection creation, and loop until a connection become idle / a new connection is created.- Returns:
- a connection object
- Throws:
java.sql.SQLException- if no connection is created when reaching timeout (connectTimeout option)
-
getConnection
public MariaDbConnection getConnection(java.lang.String username, java.lang.String password) throws java.sql.SQLException
Get new connection from pool if user and password correspond to pool. If username and password are different from pool, will return a dedicated connection.- Parameters:
username- usernamepassword- password- Returns:
- connection
- Throws:
java.sql.SQLException- if any error occur during connection
-
generatePoolTag
private java.lang.String generatePoolTag(int poolIndex)
-
getUrlParser
public UrlParser getUrlParser()
-
close
public void close() throws java.lang.InterruptedExceptionClose pool and underlying connections.- Specified by:
closein interfacejava.lang.AutoCloseable- Throws:
java.lang.InterruptedException- if interrupted
-
closeAll
private void closeAll(java.util.concurrent.ExecutorService connectionRemover, java.util.Collection<MariaDbPooledConnection> collection)
-
initializePoolGlobalState
private void initializePoolGlobalState(MariaDbConnection connection) throws java.sql.SQLException
- Throws:
java.sql.SQLException
-
getPoolTag
public java.lang.String getPoolTag()
-
equals
public boolean equals(java.lang.Object obj)
- Overrides:
equalsin classjava.lang.Object
-
hashCode
public int hashCode()
- Overrides:
hashCodein classjava.lang.Object
-
getGlobalInfo
public GlobalStateInfo getGlobalInfo()
-
getActiveConnections
public long getActiveConnections()
- Specified by:
getActiveConnectionsin interfacePoolMBean
-
getTotalConnections
public long getTotalConnections()
- Specified by:
getTotalConnectionsin interfacePoolMBean
-
getIdleConnections
public long getIdleConnections()
- Specified by:
getIdleConnectionsin interfacePoolMBean
-
getConnectionRequests
public long getConnectionRequests()
- Specified by:
getConnectionRequestsin interfacePoolMBean
-
registerJmx
private void registerJmx() throws java.lang.Exception- Throws:
java.lang.Exception
-
unRegisterJmx
private void unRegisterJmx() throws java.lang.Exception- Throws:
java.lang.Exception
-
testGetConnectionIdleThreadIds
public java.util.List<java.lang.Long> testGetConnectionIdleThreadIds()
For testing purpose only.- Returns:
- current thread id's
-
resetStaticGlobal
public void resetStaticGlobal()
JMX method to remove state (will be reinitialized on next connection creation).- Specified by:
resetStaticGlobalin interfacePoolMBean
-
-