SpringBoot2.2.x(八)整合druid

本系列文章都是基于SpringBoot2.2.5.RELEASE

依赖

<dependency>
     <groupId>com.alibaba</groupId>
     <artifactId>druid-spring-boot-starter</artifactId>
     <version>1.1.17</version>
</dependency>

配置文件

官方文档:

https://github.com/alibaba/druid/wiki/%E5%B8%B8%E8%A7%81%E9%97%AE%E9%A2%98

https://github.com/alibaba/druid/tree/master/druid-spring-boot-starter

# 数据库属性配置
spring.datasource.url=jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=utf-8&serverTimezone=GMT%2B8&useSSL=false
spring.datasource.username=root
spring.datasource.password=root
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver

# 连接池配置
# 初始化连接大小
spring.datasource.druid.initial-size=5
# 最小空闲连接数
spring.datasource.druid.min-idle=5
# 最大连接数
spring.datasource.druid.max-active=20

# 监控配置
# StatViewServlet配置,说明请参考Druid Wiki,配置_StatViewServlet配置
#是否启用StatViewServlet(监控页面)默认值为false
# (考虑到安全问题默认并未启动,如需启用建议设置密码或白名单以保障安全)
spring.datasource.druid.stat-view-servlet.enabled=true
# 登录监控页面用户名
spring.datasource.druid.stat-view-servlet.login-username=123456
# 登录监控页面密码
spring.datasource.druid.stat-view-servlet.login-password=123456

# WebStatFilter配置,说明请参考Druid Wiki,配置_配置WebStatFilter
# WebStatFilter用于采集web-jdbc关联监控的数据。
#是否启用StatFilter默认值false
spring.datasource.druid.web-stat-filter.enabled=true
# 排除一些不必要的url
spring.datasource.druid.web-stat-filter.exclusions=*.js,*.gif,*.jpg,*.png,*.css,*.ico,/druid/*
# 日志记录JDBC执行的SQL
spring.datasource.druid.filters=stat

启动项目

在浏览器输入:http://localhost:8080/druid/login.html

druid自动配置原理

我们的配置文件并没有设置spring.datasource.type来指定DruidDataSource,但是DruidDataSource却被注入到容器中了。查看DruidDataSourceAutoConfigure可以发现,DruidDataSourceAutoConfigureDataSourceAutoConfiguration先执行并往容器中注入DataSource组件。

@Configuration
// 类路径上需要存在 DruidDataSource.class
@ConditionalOnClass({DruidDataSource.class})
// 这个配置类在 DataSourceAutoConfiguration.class 之前执行
@AutoConfigureBefore({DataSourceAutoConfiguration.class})
@EnableConfigurationProperties({DruidStatProperties.class, DataSourceProperties.class})
@Import({
    DruidSpringAopConfiguration.class, 
    DruidStatViewServletConfiguration.class, 
    DruidWebStatFilterConfiguration.class, 
    DruidFilterConfiguration.class})
public class DruidDataSourceAutoConfigure {
    private static final Logger LOGGER = LoggerFactory.getLogger(DruidDataSourceAutoConfigure.class);

    public DruidDataSourceAutoConfigure() {
    }
    // 注入 DruidDataSource 组件
    @Bean(
        initMethod = "init"
    )
    @ConditionalOnMissingBean
    public DataSource dataSource() {
        LOGGER.info("Init DruidDataSource");
        return new DruidDataSourceWrapper();
    }
}
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值