package com.stylefeng.guns.core.config.properties;
|
|
import com.alibaba.druid.pool.DruidDataSource;
|
|
import java.sql.SQLException;
|
|
/**
|
* <p>数据库数据源配置</p>
|
* <p>说明:这个类中包含了许多默认配置,若这些配置符合您的情况,您可以不用管,若不符合,建议不要修改本类,建议直接在"application.yml"中配置即可</p>
|
* @author stylefeng
|
* @date 2017-05-21 11:18
|
*/
|
public class DruidProperties {
|
|
private String url = "jdbc:mysql://127.0.0.1:3306/guns?autoReconnect=true&useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull";
|
|
private String username = "root";
|
|
private String password = "root";
|
|
private String driverClassName = "com.mysql.cj.jdbc.Driver";
|
|
private Integer initialSize = 100;
|
|
private Integer minIdle = 100;
|
|
private Integer maxActive = 500;
|
|
private Integer maxWait = 60000;
|
|
private Integer timeBetweenEvictionRunsMillis = 60000;
|
|
private Integer minEvictableIdleTimeMillis = 300000;
|
|
private String validationQuery = "SELECT 'x'";
|
|
private Boolean testWhileIdle = true;
|
|
private Boolean testOnBorrow = false;
|
|
private Boolean testOnReturn = false;
|
|
private Boolean poolPreparedStatements = true;
|
|
private Integer maxPoolPreparedStatementPerConnectionSize = 20;
|
|
private String filters = "stat";
|
|
public void config(DruidDataSource dataSource) {
|
|
dataSource.setUrl(url);
|
dataSource.setUsername(username);
|
dataSource.setPassword(password);
|
|
dataSource.setDriverClassName(driverClassName);
|
dataSource.setInitialSize(initialSize); //定义初始连接数
|
dataSource.setMinIdle(minIdle); //最小空闲
|
dataSource.setMaxActive(maxActive); //定义最大连接数
|
dataSource.setMaxWait(maxWait); //最长等待时间
|
|
// 配置间隔多久才进行一次检测,检测需要关闭的空闲连接,单位是毫秒
|
dataSource.setTimeBetweenEvictionRunsMillis(timeBetweenEvictionRunsMillis);
|
|
// 配置一个连接在池中最小生存的时间,单位是毫秒
|
dataSource.setMinEvictableIdleTimeMillis(minEvictableIdleTimeMillis);
|
dataSource.setValidationQuery(validationQuery);
|
dataSource.setTestWhileIdle(testWhileIdle);
|
dataSource.setTestOnBorrow(testOnBorrow);
|
dataSource.setTestOnReturn(testOnReturn);
|
|
// 打开PSCache,并且指定每个连接上PSCache的大小
|
dataSource.setPoolPreparedStatements(poolPreparedStatements);
|
dataSource.setMaxPoolPreparedStatementPerConnectionSize(maxPoolPreparedStatementPerConnectionSize);
|
|
try {
|
dataSource.setFilters(filters);
|
} catch (SQLException e) {
|
e.printStackTrace();
|
}
|
}
|
|
public String getUrl() {
|
return url;
|
}
|
|
public void setUrl(String url) {
|
this.url = url;
|
}
|
|
public String getUsername() {
|
return username;
|
}
|
|
public void setUsername(String username) {
|
this.username = username;
|
}
|
|
public String getPassword() {
|
return password;
|
}
|
|
public void setPassword(String password) {
|
this.password = password;
|
}
|
|
public String getDriverClassName() {
|
return driverClassName;
|
}
|
|
public void setDriverClassName(String driverClassName) {
|
this.driverClassName = driverClassName;
|
}
|
|
public Integer getInitialSize() {
|
return initialSize;
|
}
|
|
public void setInitialSize(Integer initialSize) {
|
this.initialSize = initialSize;
|
}
|
|
public Integer getMinIdle() {
|
return minIdle;
|
}
|
|
public void setMinIdle(Integer minIdle) {
|
this.minIdle = minIdle;
|
}
|
|
public Integer getMaxActive() {
|
return maxActive;
|
}
|
|
public void setMaxActive(Integer maxActive) {
|
this.maxActive = maxActive;
|
}
|
|
public Integer getMaxWait() {
|
return maxWait;
|
}
|
|
public void setMaxWait(Integer maxWait) {
|
this.maxWait = maxWait;
|
}
|
|
public Integer getTimeBetweenEvictionRunsMillis() {
|
return timeBetweenEvictionRunsMillis;
|
}
|
|
public void setTimeBetweenEvictionRunsMillis(Integer timeBetweenEvictionRunsMillis) {
|
this.timeBetweenEvictionRunsMillis = timeBetweenEvictionRunsMillis;
|
}
|
|
public Integer getMinEvictableIdleTimeMillis() {
|
return minEvictableIdleTimeMillis;
|
}
|
|
public void setMinEvictableIdleTimeMillis(Integer minEvictableIdleTimeMillis) {
|
this.minEvictableIdleTimeMillis = minEvictableIdleTimeMillis;
|
}
|
|
public String getValidationQuery() {
|
return validationQuery;
|
}
|
|
public void setValidationQuery(String validationQuery) {
|
this.validationQuery = validationQuery;
|
}
|
|
public Boolean getTestWhileIdle() {
|
return testWhileIdle;
|
}
|
|
public void setTestWhileIdle(Boolean testWhileIdle) {
|
this.testWhileIdle = testWhileIdle;
|
}
|
|
public Boolean getTestOnBorrow() {
|
return testOnBorrow;
|
}
|
|
public void setTestOnBorrow(Boolean testOnBorrow) {
|
this.testOnBorrow = testOnBorrow;
|
}
|
|
public Boolean getTestOnReturn() {
|
return testOnReturn;
|
}
|
|
public void setTestOnReturn(Boolean testOnReturn) {
|
this.testOnReturn = testOnReturn;
|
}
|
|
public Boolean getPoolPreparedStatements() {
|
return poolPreparedStatements;
|
}
|
|
public void setPoolPreparedStatements(Boolean poolPreparedStatements) {
|
this.poolPreparedStatements = poolPreparedStatements;
|
}
|
|
public Integer getMaxPoolPreparedStatementPerConnectionSize() {
|
return maxPoolPreparedStatementPerConnectionSize;
|
}
|
|
public void setMaxPoolPreparedStatementPerConnectionSize(Integer maxPoolPreparedStatementPerConnectionSize) {
|
this.maxPoolPreparedStatementPerConnectionSize = maxPoolPreparedStatementPerConnectionSize;
|
}
|
|
public String getFilters() {
|
return filters;
|
}
|
|
public void setFilters(String filters) {
|
this.filters = filters;
|
}
|
}
|