阿里Druid 连接池受欢迎的组件,本地测试打包的时候,没有问题。如果数据库修改线上的信息时候出现报错,无法正常打包。这就需要打包时候剔除druid初始化。
1. druid配置
pring:
cache:
ehcache:
config: classpath:ehcache.xml
datasource:
type: com.alibaba.druid.pool.DruidDataSource
driverClassName: com.mysql.cj.jdbc.Driver
url: jdbc:mysql://localhost:3306/xxxx?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8
username: xxxxxx
password: xxxxxxx
druid:
# 初始连接数
initialSize: 5
# 最小连接池数量
minIdle: 10
# 最大连接池数量
maxActive: 20
# 配置获取连接等待超时的时间
maxWait: 60000
# 配置连接超时时间
connectTimeout: 30000
# 配置网络超时时间
socketTimeout: 60000
# 配置间隔多久才进行一次检测,检测需要关闭的空闲连接,单位是毫秒
timeBetweenEvictionRunsMillis: 60000
# 配置一个连接在池中最小生存的时间,单位是毫秒
minEvictableIdleTimeMillis: 300000
# 配置一个连接在池中最大生存的时间,单位是毫秒
maxEvictableIdleTimeMillis: 900000
# 配置检测连接是否有效
validationQuery: SELECT 1 FROM DUAL
testWhileIdle: true
testOnBorrow: false
testOnReturn: false
webStatFilter:
enabled: true
statViewServlet:
enabled: true
# 设置白名单,不填则允许所有访问
allow:
url-pattern: /druid/*
# 控制台管理用户名和密码
login-username: xxxx
login-password: 123456
filter:
stat:
enabled: true
# 慢SQL记录
log-slow-sql: true
slow-sql-millis: 1000
merge-sql: true
wall:
config:
multi-statement-allow: true
2. 配置类
@Configuration
public class DataSourceConfig {
@Bean
@ConditionalOnProperty(name = "init.druid", havingValue = "true", matchIfMissing = false)
public DataSource druidDataSource() {
// 配置并返回Druid数据源
return DruidDataSourceBuilder.create().build();
}
}
3. yam 配置参数
init:
druid: true
修改线上数据库账号密码,可完美打包。----有活@我