public class DataSourceFactory extends Object
ManagedDataSource
s.
Configuration Parameters:
Name | Default | Description |
driverClass |
REQUIRED | The full name of the JDBC driver class. |
url |
REQUIRED | The URL of the server. |
user |
REQUIRED | The username used to connect to the server. |
password |
none | The password used to connect to the server. |
abandonWhenPercentageFull |
0 |
Connections that have been abandoned (timed out) won't get closed and reported up
unless the number of connections in use are above the percentage defined by
abandonWhenPercentageFull . The value should be between 0-100.
|
alternateUsernamesAllowed |
false |
Set to true if the call
getConnection(username,password)
is allowed. This is used for when the pool is used by an application accessing
multiple schemas. There is a performance impact turning this option on, even when not
used.
|
commitOnReturn |
false |
Set to true if you want the connection pool to commit any pending transaction when a connection is returned. |
autoCommitByDefault |
JDBC driver's default | The default auto-commit state of the connections. |
readOnlyByDefault |
JDBC driver's default | The default read-only state of the connections. |
properties |
none | Any additional JDBC driver parameters. |
defaultCatalog |
none | The default catalog to use for the connections. |
defaultTransactionIsolation |
JDBC driver default |
The default transaction isolation to use for the connections. Can be one of
none , default , read-uncommitted , read-committed ,
repeatable-read , or serializable .
|
useFairQueue |
true |
If true , calls to getConnection are handled in a FIFO manner.
|
initialSize |
10 | The initial size of the connection pool. |
minSize |
10 | The minimum size of the connection pool. |
maxSize |
100 | The maximum size of the connection pool. |
initializationQuery |
none | A custom query to be run when a connection is first created. |
logAbandonedConnections |
false |
If true , logs stack traces of abandoned connections.
|
logValidationErrors |
false |
If true , logs errors when connections fail validation.
|
maxConnectionAge |
none |
If set, connections which have been open for longer than maxConnectionAge are
closed when returned.
|
maxWaitForConnection |
30 seconds | If a request for a connection is blocked for longer than this period, an exception will be thrown. |
minIdleTime |
1 minute | The minimum amount of time an connection must sit idle in the pool before it is eligible for eviction. |
validationQuery |
SELECT 1 |
The SQL query that will be used to validate connections from this pool before returning them to the caller or pool. If specified, this query does not have to return any data, it just can't throw a SQLException. |
validationQueryTimeout |
none | The timeout before a connection validation queries fail. |
checkConnectionWhileIdle |
true |
Set to true if query validation should take place while the connection is idle. |
checkConnectionOnBorrow |
false |
Whether or not connections will be validated before being borrowed from the pool. If the connection fails to validate, it will be dropped from the pool, and another will be borrowed. |
checkConnectionOnConnect |
false |
Whether or not connections will be validated before being added to the pool. If the connection fails to validate, it won't be added to the pool. |
checkConnectionOnReturn |
false |
Whether or not connections will be validated after being returned to the pool. If the connection fails to validate, it will be dropped from the pool. |
autoCommentsEnabled |
true |
Whether or not ORMs should automatically add comments. |
evictionInterval |
5 seconds | The amount of time to sleep between runs of the idle connection validation, abandoned cleaner and idle pool resizing. |
validationInterval |
30 seconds | To avoid excess validation, only run validation once every interval. |
Modifier and Type | Class and Description |
---|---|
static class |
DataSourceFactory.TransactionIsolation |
Constructor and Description |
---|
DataSourceFactory() |
public boolean isAutoCommentsEnabled()
public void setAutoCommentsEnabled(boolean autoCommentsEnabled)
public String getDriverClass()
public void setDriverClass(String driverClass)
public String getUser()
public void setUser(String user)
public String getPassword()
public void setPassword(String password)
public String getUrl()
public void setUrl(String url)
public io.dropwizard.util.Duration getMaxWaitForConnection()
public void setMaxWaitForConnection(io.dropwizard.util.Duration maxWaitForConnection)
public String getValidationQuery()
public void setValidationQuery(String validationQuery)
public int getMinSize()
public void setMinSize(int minSize)
public int getMaxSize()
public void setMaxSize(int maxSize)
public boolean getCheckConnectionWhileIdle()
public void setCheckConnectionWhileIdle(boolean checkConnectionWhileIdle)
@Deprecated public boolean isDefaultReadOnly()
@Deprecated public void setDefaultReadOnly(boolean defaultReadOnly)
@ValidationMethod(message=".minSize must be less than or equal to maxSize") public boolean isMinSizeLessThanMaxSize()
@ValidationMethod(message=".initialSize must be less than or equal to maxSize") public boolean isInitialSizeLessThanMaxSize()
@ValidationMethod(message=".initialSize must be greater than or equal to minSize") public boolean isInitialSizeGreaterThanMinSize()
public int getAbandonWhenPercentageFull()
public void setAbandonWhenPercentageFull(int percentage)
public boolean isAlternateUsernamesAllowed()
public void setAlternateUsernamesAllowed(boolean allow)
public boolean getCommitOnReturn()
public void setCommitOnReturn(boolean commitOnReturn)
public Boolean getAutoCommitByDefault()
public void setAutoCommitByDefault(Boolean autoCommit)
public String getDefaultCatalog()
public void setDefaultCatalog(String defaultCatalog)
public Boolean getReadOnlyByDefault()
public void setReadOnlyByDefault(Boolean readOnlyByDefault)
public DataSourceFactory.TransactionIsolation getDefaultTransactionIsolation()
public void setDefaultTransactionIsolation(DataSourceFactory.TransactionIsolation isolation)
public boolean getUseFairQueue()
public void setUseFairQueue(boolean fair)
public int getInitialSize()
public void setInitialSize(int initialSize)
public String getInitializationQuery()
public void setInitializationQuery(String query)
public boolean getLogAbandonedConnections()
public void setLogAbandonedConnections(boolean log)
public boolean getLogValidationErrors()
public void setLogValidationErrors(boolean log)
public com.google.common.base.Optional<io.dropwizard.util.Duration> getMaxConnectionAge()
public void setMaxConnectionAge(io.dropwizard.util.Duration age)
public io.dropwizard.util.Duration getMinIdleTime()
public void setMinIdleTime(io.dropwizard.util.Duration time)
public boolean getCheckConnectionOnBorrow()
public void setCheckConnectionOnBorrow(boolean checkConnectionOnBorrow)
public boolean getCheckConnectionOnConnect()
public void setCheckConnectionOnConnect(boolean checkConnectionOnConnect)
public boolean getCheckConnectionOnReturn()
public void setCheckConnectionOnReturn(boolean checkConnectionOnReturn)
public io.dropwizard.util.Duration getEvictionInterval()
public void setEvictionInterval(io.dropwizard.util.Duration interval)
public io.dropwizard.util.Duration getValidationInterval()
public void setValidationInterval(io.dropwizard.util.Duration validationInterval)
public com.google.common.base.Optional<io.dropwizard.util.Duration> getValidationQueryTimeout()
public void setValidationQueryTimeout(io.dropwizard.util.Duration validationQueryTimeout)
public ManagedDataSource build(com.codahale.metrics.MetricRegistry metricRegistry, String name)
Copyright © 2015. All rights reserved.