Class PooledDataSource
java.lang.Object
org.apache.ibatis.datasource.pooled.PooledDataSource
- All Implemented Interfaces:
Wrapper
,CommonDataSource
,DataSource
This is a simple, synchronous, thread-safe database connection pool.
- Author:
- Clinton Begin
-
Field Summary
Modifier and TypeFieldDescriptionprotected int
protected int
protected int
protected int
protected int
protected boolean
protected String
protected int
-
Constructor Summary
ConstructorDescriptionPooledDataSource
(ClassLoader driverClassLoader, String driver, String url, String username, String password) PooledDataSource
(ClassLoader driverClassLoader, String driver, String url, Properties driverProperties) PooledDataSource
(String driver, String url, String username, String password) PooledDataSource
(String driver, String url, Properties driverProperties) PooledDataSource
(UnpooledDataSource dataSource) -
Method Summary
Modifier and TypeMethodDescriptionprotected void
finalize()
void
Closes all active and idle connections in the pool.getConnection
(String username, String password) Gets the default network timeout.int
int
int
int
int
int
int
getUrl()
boolean
boolean
boolean
isWrapperFor
(Class<?> iface) protected boolean
pingConnection
(org.apache.ibatis.datasource.pooled.PooledConnection conn) Method to check to see if a connection is still usableprotected void
pushConnection
(org.apache.ibatis.datasource.pooled.PooledConnection conn) void
setDefaultAutoCommit
(boolean defaultAutoCommit) void
setDefaultNetworkTimeout
(Integer milliseconds) Sets the default network timeout value to wait for the database operation to complete.void
setDefaultTransactionIsolationLevel
(Integer defaultTransactionIsolationLevel) void
void
setDriverProperties
(Properties driverProps) void
setLoginTimeout
(int loginTimeout) void
setLogWriter
(PrintWriter logWriter) void
setPassword
(String password) void
setPoolMaximumActiveConnections
(int poolMaximumActiveConnections) The maximum number of active connections.void
setPoolMaximumCheckoutTime
(int poolMaximumCheckoutTime) The maximum time a connection can be used before it *may* be given away again.void
setPoolMaximumIdleConnections
(int poolMaximumIdleConnections) The maximum number of idle connections.void
setPoolMaximumLocalBadConnectionTolerance
(int poolMaximumLocalBadConnectionTolerance) The maximum number of tolerance for bad connection happens in one thread which are applying for newPooledConnection
.void
setPoolPingConnectionsNotUsedFor
(int milliseconds) If a connection has not been used in this many milliseconds, ping the database to make sure the connection is still good.void
setPoolPingEnabled
(boolean poolPingEnabled) Determines if the ping query should be used.void
setPoolPingQuery
(String poolPingQuery) The query to be used to check a connection.void
setPoolTimeToWait
(int poolTimeToWait) The time to wait before retrying to get a connection.void
void
setUsername
(String username) <T> T
static Connection
unwrapConnection
(Connection conn) Unwraps a pooled connection to get to the 'real' connection
-
Field Details
-
poolMaximumActiveConnections
protected int poolMaximumActiveConnections -
poolMaximumIdleConnections
protected int poolMaximumIdleConnections -
poolMaximumCheckoutTime
protected int poolMaximumCheckoutTime -
poolTimeToWait
protected int poolTimeToWait -
poolMaximumLocalBadConnectionTolerance
protected int poolMaximumLocalBadConnectionTolerance -
poolPingQuery
-
poolPingEnabled
protected boolean poolPingEnabled -
poolPingConnectionsNotUsedFor
protected int poolPingConnectionsNotUsedFor
-
-
Constructor Details
-
PooledDataSource
public PooledDataSource() -
PooledDataSource
-
PooledDataSource
-
PooledDataSource
-
PooledDataSource
public PooledDataSource(ClassLoader driverClassLoader, String driver, String url, String username, String password) -
PooledDataSource
public PooledDataSource(ClassLoader driverClassLoader, String driver, String url, Properties driverProperties)
-
-
Method Details
-
getConnection
- Specified by:
getConnection
in interfaceDataSource
- Throws:
SQLException
-
getConnection
- Specified by:
getConnection
in interfaceDataSource
- Throws:
SQLException
-
setLoginTimeout
public void setLoginTimeout(int loginTimeout) - Specified by:
setLoginTimeout
in interfaceCommonDataSource
-
getLoginTimeout
public int getLoginTimeout()- Specified by:
getLoginTimeout
in interfaceCommonDataSource
-
setLogWriter
- Specified by:
setLogWriter
in interfaceCommonDataSource
-
getLogWriter
- Specified by:
getLogWriter
in interfaceCommonDataSource
-
setDriver
-
setUrl
-
setUsername
-
setPassword
-
setDefaultAutoCommit
public void setDefaultAutoCommit(boolean defaultAutoCommit) -
setDefaultTransactionIsolationLevel
-
setDriverProperties
-
setDefaultNetworkTimeout
Sets the default network timeout value to wait for the database operation to complete. SeeConnection.setNetworkTimeout(java.util.concurrent.Executor, int)
- Parameters:
milliseconds
- The time in milliseconds to wait for the database operation to complete.- Since:
- 3.5.2
-
setPoolMaximumActiveConnections
public void setPoolMaximumActiveConnections(int poolMaximumActiveConnections) The maximum number of active connections.- Parameters:
poolMaximumActiveConnections
- The maximum number of active connections
-
setPoolMaximumIdleConnections
public void setPoolMaximumIdleConnections(int poolMaximumIdleConnections) The maximum number of idle connections.- Parameters:
poolMaximumIdleConnections
- The maximum number of idle connections
-
setPoolMaximumLocalBadConnectionTolerance
public void setPoolMaximumLocalBadConnectionTolerance(int poolMaximumLocalBadConnectionTolerance) The maximum number of tolerance for bad connection happens in one thread which are applying for newPooledConnection
.- Parameters:
poolMaximumLocalBadConnectionTolerance
- max tolerance for bad connection happens in one thread- Since:
- 3.4.5
-
setPoolMaximumCheckoutTime
public void setPoolMaximumCheckoutTime(int poolMaximumCheckoutTime) The maximum time a connection can be used before it *may* be given away again.- Parameters:
poolMaximumCheckoutTime
- The maximum time
-
setPoolTimeToWait
public void setPoolTimeToWait(int poolTimeToWait) The time to wait before retrying to get a connection.- Parameters:
poolTimeToWait
- The time to wait
-
setPoolPingQuery
The query to be used to check a connection.- Parameters:
poolPingQuery
- The query
-
setPoolPingEnabled
public void setPoolPingEnabled(boolean poolPingEnabled) Determines if the ping query should be used.- Parameters:
poolPingEnabled
- True if we need to check a connection before using it
-
setPoolPingConnectionsNotUsedFor
public void setPoolPingConnectionsNotUsedFor(int milliseconds) If a connection has not been used in this many milliseconds, ping the database to make sure the connection is still good.- Parameters:
milliseconds
- the number of milliseconds of inactivity that will trigger a ping
-
getDriver
-
getUrl
-
getUsername
-
getPassword
-
isAutoCommit
public boolean isAutoCommit() -
getDefaultTransactionIsolationLevel
-
getDriverProperties
-
getDefaultNetworkTimeout
Gets the default network timeout.- Returns:
- the default network timeout
- Since:
- 3.5.2
-
getPoolMaximumActiveConnections
public int getPoolMaximumActiveConnections() -
getPoolMaximumIdleConnections
public int getPoolMaximumIdleConnections() -
getPoolMaximumLocalBadConnectionTolerance
public int getPoolMaximumLocalBadConnectionTolerance() -
getPoolMaximumCheckoutTime
public int getPoolMaximumCheckoutTime() -
getPoolTimeToWait
public int getPoolTimeToWait() -
getPoolPingQuery
-
isPoolPingEnabled
public boolean isPoolPingEnabled() -
getPoolPingConnectionsNotUsedFor
public int getPoolPingConnectionsNotUsedFor() -
forceCloseAll
public void forceCloseAll()Closes all active and idle connections in the pool. -
getPoolState
-
pushConnection
protected void pushConnection(org.apache.ibatis.datasource.pooled.PooledConnection conn) throws SQLException - Throws:
SQLException
-
pingConnection
protected boolean pingConnection(org.apache.ibatis.datasource.pooled.PooledConnection conn) Method to check to see if a connection is still usable- Parameters:
conn
- - the connection to check- Returns:
- True if the connection is still usable
-
unwrapConnection
Unwraps a pooled connection to get to the 'real' connection- Parameters:
conn
- - the pooled connection to unwrap- Returns:
- The 'real' connection
-
finalize
-
unwrap
- Specified by:
unwrap
in interfaceWrapper
- Throws:
SQLException
-
isWrapperFor
- Specified by:
isWrapperFor
in interfaceWrapper
-
getParentLogger
- Specified by:
getParentLogger
in interfaceCommonDataSource
-