| package com.supersavedriving.user.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 = 2; | 
|   | 
|     private Integer minIdle = 1; | 
|   | 
|     private Integer maxActive = 20; | 
|   | 
|     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; | 
|     } | 
| } |