public interface AbandonedConnectionTimeoutCallback
UniversalConnectionPool
and PoolDataSource
.
The callback object is optionally registered with each pooled connection or using any of its logical connection proxies, allowing applications to perform customized handling when this particular connection is deemed abandoned by the pool.
The handleTimedOutConnection(...)
method is invoked when a borrowed connection is deemed abandoned by the Universal Connection Pool. Applications can choose to completely override the pool's handling, invoke additional handling actions, or simply assume the pool's default handling. For example, JDBC applications can invoke cancel()
, close()
and rollback()
methods on the abandoned connection within this method.
It is an error to register more than one AbandonedConnectionTimeoutCallback
on the same connection. Any such attempt will result in a UniversalConnectionPoolException
at the pool layer, or an exception specific to the type of a Universal Connection Pool Adapter (for example, JDBC, JCA, and so forth) like java.sql.SQLException.
Modifier and Type | Method and Description |
---|---|
boolean |
handleTimedOutConnection()
Sets whether or not the connection pool is responsible for handling abandoned connections.
|
boolean handleTimedOutConnection()
The method implementation must return true
if the application handles the abandonedConnectionTimeout
in place of the pool, and must return false
if the application wants the pool to take over the abandoned connection handling. In the former case, applications have the option of simply holding on to the borrowed connection or performing some actions and returning the abandoned connection to the pool. For the pool layer, this means calling returnConnection()
; while, for the pool adapter layer, this means calling close()
on the connection proxy.
true
; otherwise, return false
.