Package com.zaxxer.hikari
Class HikariDataSource
- java.lang.Object
- 
- com.zaxxer.hikari.HikariConfig
- 
- com.zaxxer.hikari.HikariDataSource
 
 
- 
- All Implemented Interfaces:
- HikariConfigMXBean,- java.io.Closeable,- java.lang.AutoCloseable,- java.sql.Wrapper,- javax.sql.CommonDataSource,- javax.sql.DataSource
 
 public class HikariDataSource extends HikariConfig implements javax.sql.DataSource, java.io.Closeable The HikariCP pooled DataSource.- Author:
- Brett Wooldridge
 
- 
- 
Constructor SummaryConstructors Constructor Description HikariDataSource()Default constructor.HikariDataSource(HikariConfig configuration)Construct a HikariDataSource with the specified configuration.
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description voidclose()Shutdown the DataSource and its associated pool.voidevictConnection(java.sql.Connection connection)Evict a connection from the pool.java.sql.ConnectiongetConnection()java.sql.ConnectiongetConnection(java.lang.String username, java.lang.String password)HikariConfigMXBeangetHikariConfigMXBean()Get theHikariConfigMXBeanfor this HikariDataSource instance.HikariPoolMXBeangetHikariPoolMXBean()Get theHikariPoolMXBeanfor this HikariDataSource instance.intgetLoginTimeout()java.io.PrintWritergetLogWriter()java.util.logging.LoggergetParentLogger()booleanisClosed()Determine whether the HikariDataSource has been closed.booleanisRunning()Returnstrueif the pool as been started and is not suspended or shutdown.booleanisWrapperFor(java.lang.Class<?> iface)voidsetHealthCheckRegistry(java.lang.Object healthCheckRegistry)Set the HealthCheckRegistry that will be used for registration of health checks by HikariCP.voidsetLoginTimeout(int seconds)voidsetLogWriter(java.io.PrintWriter out)voidsetMetricRegistry(java.lang.Object metricRegistry)Set a MetricRegistry instance to use for registration of metrics used by HikariCP.voidsetMetricsTrackerFactory(MetricsTrackerFactory metricsTrackerFactory)java.lang.StringtoString()<T> Tunwrap(java.lang.Class<T> iface)- 
Methods inherited from class com.zaxxer.hikari.HikariConfigaddDataSourceProperty, addHealthCheckProperty, copyStateTo, getCatalog, getConnectionInitSql, getConnectionTestQuery, getConnectionTimeout, getDataSource, getDataSourceClassName, getDataSourceJNDI, getDataSourceProperties, getDriverClassName, getExceptionOverrideClassName, getHealthCheckProperties, getHealthCheckRegistry, getIdleTimeout, getInitializationFailTimeout, getJdbcUrl, getKeepaliveTime, getLeakDetectionThreshold, getMaximumPoolSize, getMaxLifetime, getMetricRegistry, getMetricsTrackerFactory, getMinimumIdle, getPassword, getPoolName, getScheduledExecutor, getSchema, getThreadFactory, getTransactionIsolation, getUsername, getValidationTimeout, isAllowPoolSuspension, isAutoCommit, isIsolateInternalQueries, isReadOnly, isRegisterMbeans, setAllowPoolSuspension, setAutoCommit, setCatalog, setConnectionInitSql, setConnectionTestQuery, setConnectionTimeout, setDataSource, setDataSourceClassName, setDataSourceJNDI, setDataSourceProperties, setDriverClassName, setExceptionOverrideClassName, setHealthCheckProperties, setIdleTimeout, setInitializationFailTimeout, setIsolateInternalQueries, setJdbcUrl, setKeepaliveTime, setLeakDetectionThreshold, setMaximumPoolSize, setMaxLifetime, setMinimumIdle, setPassword, setPoolName, setReadOnly, setRegisterMbeans, setScheduledExecutor, setSchema, setThreadFactory, setTransactionIsolation, setUsername, setValidationTimeout, validate
 
- 
 
- 
- 
- 
Constructor Detail- 
HikariDataSourcepublic HikariDataSource() Default constructor. Setters are used to configure the pool. Using this constructor vs.HikariDataSource(HikariConfig)will result ingetConnection()performance that is slightly lower due to lazy initialization checks. The first call togetConnection()starts the pool. Once the pool is started, the configuration is "sealed" and no further configuration changes are possible -- except viaHikariConfigMXBeanmethods.
 - 
HikariDataSourcepublic HikariDataSource(HikariConfig configuration) Construct a HikariDataSource with the specified configuration. TheHikariConfigis copied and the pool is started by invoking this constructor. TheHikariConfigcan be modified without affecting the HikariDataSource and used to initialize another HikariDataSource instance.- Parameters:
- configuration- a HikariConfig instance
 
 
- 
 - 
Method Detail- 
getConnectionpublic java.sql.Connection getConnection() throws java.sql.SQLException- Specified by:
- getConnectionin interface- javax.sql.DataSource
- Throws:
- java.sql.SQLException
 
 - 
getConnectionpublic java.sql.Connection getConnection(java.lang.String username, java.lang.String password) throws java.sql.SQLException- Specified by:
- getConnectionin interface- javax.sql.DataSource
- Throws:
- java.sql.SQLException
 
 - 
getLogWriterpublic java.io.PrintWriter getLogWriter() throws java.sql.SQLException- Specified by:
- getLogWriterin interface- javax.sql.CommonDataSource
- Specified by:
- getLogWriterin interface- javax.sql.DataSource
- Throws:
- java.sql.SQLException
 
 - 
setLogWriterpublic void setLogWriter(java.io.PrintWriter out) throws java.sql.SQLException- Specified by:
- setLogWriterin interface- javax.sql.CommonDataSource
- Specified by:
- setLogWriterin interface- javax.sql.DataSource
- Throws:
- java.sql.SQLException
 
 - 
setLoginTimeoutpublic void setLoginTimeout(int seconds) throws java.sql.SQLException- Specified by:
- setLoginTimeoutin interface- javax.sql.CommonDataSource
- Specified by:
- setLoginTimeoutin interface- javax.sql.DataSource
- Throws:
- java.sql.SQLException
 
 - 
getLoginTimeoutpublic int getLoginTimeout() throws java.sql.SQLException- Specified by:
- getLoginTimeoutin interface- javax.sql.CommonDataSource
- Specified by:
- getLoginTimeoutin interface- javax.sql.DataSource
- Throws:
- java.sql.SQLException
 
 - 
getParentLoggerpublic java.util.logging.Logger getParentLogger() throws java.sql.SQLFeatureNotSupportedException- Specified by:
- getParentLoggerin interface- javax.sql.CommonDataSource
- Throws:
- java.sql.SQLFeatureNotSupportedException
 
 - 
unwrappublic <T> T unwrap(java.lang.Class<T> iface) throws java.sql.SQLException- Specified by:
- unwrapin interface- java.sql.Wrapper
- Throws:
- java.sql.SQLException
 
 - 
isWrapperForpublic boolean isWrapperFor(java.lang.Class<?> iface) throws java.sql.SQLException- Specified by:
- isWrapperForin interface- java.sql.Wrapper
- Throws:
- java.sql.SQLException
 
 - 
setMetricRegistrypublic void setMetricRegistry(java.lang.Object metricRegistry) Set a MetricRegistry instance to use for registration of metrics used by HikariCP.- Overrides:
- setMetricRegistryin class- HikariConfig
- Parameters:
- metricRegistry- the MetricRegistry instance to use
 
 - 
setMetricsTrackerFactorypublic void setMetricsTrackerFactory(MetricsTrackerFactory metricsTrackerFactory) - Overrides:
- setMetricsTrackerFactoryin class- HikariConfig
 
 - 
setHealthCheckRegistrypublic void setHealthCheckRegistry(java.lang.Object healthCheckRegistry) Set the HealthCheckRegistry that will be used for registration of health checks by HikariCP. Currently only Codahale/DropWizard is supported for health checks. Default isnull.- Overrides:
- setHealthCheckRegistryin class- HikariConfig
- Parameters:
- healthCheckRegistry- the HealthCheckRegistry to be used
 
 - 
isRunningpublic boolean isRunning() Returnstrueif the pool as been started and is not suspended or shutdown.- Returns:
- trueif the pool as been started and is not suspended or shutdown.
 
 - 
getHikariPoolMXBeanpublic HikariPoolMXBean getHikariPoolMXBean() Get theHikariPoolMXBeanfor this HikariDataSource instance. If this method is called on aHikariDataSourcethat has been constructed without aHikariConfiginstance, and before an initial call to#getConnection(), the return value will benull.- Returns:
- the HikariPoolMXBeaninstance, ornull.
 
 - 
getHikariConfigMXBeanpublic HikariConfigMXBean getHikariConfigMXBean() Get theHikariConfigMXBeanfor this HikariDataSource instance.- Returns:
- the HikariConfigMXBeaninstance.
 
 - 
evictConnectionpublic void evictConnection(java.sql.Connection connection) Evict a connection from the pool. If the connection has already been closed (returned to the pool) this may result in a "soft" eviction; the connection will be evicted sometime in the future if it is currently in use. If the connection has not been closed, the eviction is immediate.- Parameters:
- connection- the connection to evict from the pool
 
 - 
closepublic void close() Shutdown the DataSource and its associated pool.- Specified by:
- closein interface- java.lang.AutoCloseable
- Specified by:
- closein interface- java.io.Closeable
 
 - 
isClosedpublic boolean isClosed() Determine whether the HikariDataSource has been closed.- Returns:
- true if the HikariDataSource has been closed, false otherwise
 
 - 
toStringpublic java.lang.String toString() - Overrides:
- toStringin class- java.lang.Object
 
 
- 
 
-