SpringBoot整合阿里 Druid 数据源的实例详解

目录
  • 1. 在容器中注册 DruidDataSource 数据源。
  • 2. Druid 数据源各种属性配置方法
  • 3. 开启Druid的内置监控页面
  • 4. 打开 Druid 监控统计功能
  • 5. 配置Web和Spring关联监控
  • 6. 配置防火墙:
  • 7. 给监控页加入账号密码

前言:今年是我的第二个 1024 了 ,和我一起大声说出来,技术宅改变世界!!!

本节主要介绍的是:SpringBoot 整合阿里 Druid 数据源手动配置方法

1. 在容器中注册 DruidDataSource 数据源。

编写数据源配置类 MyDataSourseConfig.class,并在容器中注册 DruidDataSource 数据源。

代码示例如下:

@Configuration
public class MyDataSourseConfig {
    @Bean
    @ConfigurationProperties("spring.datasource") // 属性与配置文件绑定
    public DataSource dataSource(){
        return new DruidDataSource();
    }
}

2. Druid 数据源各种属性配置方法

方法一(不推荐): 直接在配置类中通过为自定义的 DruidDataSource 组件 通过 set 设置各种属性,来实现数据源的配置。

代码示例如下:

@Configuration
public class MyDataSourseConfig {
    @Bean
    public DataSource dataSource(){

        DruidDataSource druidDataSource = new DruidDataSource();
        druidDataSource.setUrl("jdbc:mysql://localhost:3306/practice"); // 设置数据源连接 url
        // ..... 设置其他属性 .....
        return druidDataSource;
    }
}

这种方法当修养属性值时,需要大量修改源代码,因此不推荐。

方法二(推荐):通过 @ConfigurationProperties(“spring.datasource”) 注释将组件与配置文件中的 spring.datasource 项绑定,这样在修改自定义数据源属性时,直接在 application.yaml 文件的 spring.datasource 配置项下修改即可。代码示例如下:

spring:
  datasource:
    url: jdbc:mysql://localhost:3306/practice
    username: root
    password: 5201314love
    driver-class-name: com.mysql.jdbc.Driver

可通过自定义数据源组件注册到容器中修改默认数据源原理:

DataSourceAutoConfiguration.class 数据源自动配置类中,有如下设置。其表示容器中没有数据源,才自动配置 Hikari 数据源。若有数据源则使用容器中的数据源。

3. 开启Druid的内置监控页面

在容器中放一 Servlet ,具体操作方法为在 Druid数据源 配置类中注册一ServletRegistrationBean 组件到容器,ServletRegistrationBean 的Servlet 类型为 StatViewServlet 。代码示例如下:

注意点:访问的 url 为 "/druid/*" ,是一个 * 而不是双 **

@Configuration
public class MyDataSourseConfig {
    @Bean
    @ConfigurationProperties("spring.datasource")
    public DataSource dataSource(){
        return new DruidDataSource();
    }

    // 配置 druid 监控页功能 —— 在容器中放一 Servlet
    @Bean
    public ServletRegistrationBean statViewServlet(){
        StatViewServlet statViewServlet = new StatViewServlet();
        ServletRegistrationBean<StatViewServlet> registrationBean = new ServletRegistrationBean<StatViewServlet>(statViewServlet, "/druid/*");
        return registrationBean;
    }
}

4. 打开 Druid 监控统计功能

只是开启了监控页功能并不能让我们使用 Druid 为我们提供的 SQL 监控等功能。还需要为数据源配置 StatFilter,具体方法是通过 setFilters(“stat”) 方法配置。代码如下:

    @Bean
    @ConfigurationProperties("spring.datasource")
    public DataSource dataSource() throws SQLException {
        DruidDataSource druidDataSource = new DruidDataSource();
        // 加入监控功能 —— setFilters("stat");
        druidDataSource.setFilters("stat");
        return druidDataSource;
    }

这时我们再去访问数据库,可以发现SQL监控功能可用了

5. 配置Web和Spring关联监控

在容器中注册一 WebStatFilter ,通过 setUrlPatterns(Arrays.asList(“/*”) 设置监控的请求为 /** 请求。具体代码实现如下:

    // 采集 web-jdbc 关联监控的数据
    @Bean
    public FilterRegistrationBean webstatFilter(){
        WebStatFilter webStatFilter = new WebStatFilter();

        FilterRegistrationBean<WebStatFilter> registrationBean = new FilterRegistrationBean<>(webStatFilter);
        registrationBean.setUrlPatterns(Arrays.asList("/*"));
        registrationBean.addInitParameter("exclusions", "*.js,*.gif,*.jpg,*.png,*.css,*.ico,/druid/*");
        return registrationBean;
    }

6. 配置防火墙:

在数据源中通过 setFilter(“wall”) 加入 防火墙配置 (setFilter 多个值用逗号隔开)

        // 加入监控功能
        druidDataSource.setFilters("stat, wall");

小优化:
所有通过 setXXXX() 设置数据源的,都可以在配置文件中写,因为 druidDataSource 已经绑定了 spring.datasource 配置项

例如:

druidDataSource.setFilters("stat, wall");

可优化为:

spring:
  datasource:
    # ... 此处省略一堆其他配置....
    filters: stat,wall

7. 给监控页加入账号密码

在 ServletRegistrationBean 中通过 addInitParameter 加入账号密码的设置

    // 配置 druid 监控页功能 —— 在容器中放一 Servlet
    @Bean
    public ServletRegistrationBean statViewServlet(){
        StatViewServlet statViewServlet = new StatViewServlet();
        ServletRegistrationBean<StatViewServlet> registrationBean = new ServletRegistrationBean<StatViewServlet>(statViewServlet, "/druid/*");
        registrationBean.addInitParameter("loginUsername", "wanqing");
        registrationBean.addInitParameter("loginPassword", "520131");
        return registrationBean;
    }

到此这篇关于SpringBoot整合阿里 Druid 数据源的文章就介绍到这了,更多相关SpringBoot整合Druid 数据源内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

时间: 2022-11-12

SpringBoot整合Druid数据源过程详解

这篇文章主要介绍了SpringBoot整合Druid数据源过程详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 1.数据库结构 2.项目结构 3.pom.xml文件 <dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-jdbc</ar

通过springboot+mybatis+druid配置动态数据源

一.建数据库和表 1.数据库demo1放一张user表 SET FOREIGN_KEY_CHECKS=0; -- ---------------------------- -- Table structure for user -- ---------------------------- DROP TABLE IF EXISTS `user`; CREATE TABLE `user` ( `id` int(11) NOT NULL, `name` varchar(255) DEFAULT NU

Springboot mybatis plus druid多数据源解决方案 dynamic-datasource的使用详解

依赖 <dependency> <groupId>com.baomidou</groupId> <artifactId>dynamic-datasource-spring-boot-starter</artifactId> <version>2.5.0</version> </dependency> <dependency> <groupId>p6spy</groupId>

SpringBoot详解如何进行整合Druid数据源

目录 1.自定义方式 1.添加依赖 2.编写配置 3.测试 2.starter方式(推荐) 1.添加依赖 2.编写配置 3.测试 Druid是数据库连接池,它能够提供强大的监控和扩展功能.官方文档 Spring Boot整合第三方技术的两种方式: 自定义 找starter场景 1.自定义方式 使用自定义方式整合Druid 1.添加依赖 在pom.xml添加相关依赖 <!--数据库相关--> <dependency> <groupId>org.springframewor

SpringBoot使用Druid数据源的配置方法

Druid是阿里巴巴开源平台上一个数据库连接池实现,它结合了C3P0.DBCP.PROXOOL等DB池的优点,同时加入了日志监控,可以很好的监控DB池连接和SQL的执行情况,可以说是针对监控而生的DB连接池(据说是目前最好的连接池) 一.依赖 为了测试,使用jdbcTemplate <!-- jdbcTemplate --> <dependency> <groupId>org.springframework.boot</groupId> <artifa

springboot 动态数据源的实现方法(Mybatis+Druid)

Spring多数据源实现的方式大概有2中,一种是新建多个MapperScan扫描不同包,另外一种则是通过继承AbstractRoutingDataSource实现动态路由.今天作者主要基于后者做的实现,且方式1的实现比较简单这里不做过多探讨. 实现方式 方式1的实现(核心代码): @Configuration @MapperScan(basePackages = "com.goofly.test1", sqlSessionTemplateRef = "test1SqlSess

关于springboot配置druid数据源不生效问题(踩坑记)

pom文件 如果你的springboot项目要用到druid,那么这三个依赖必不可少: <dependency> <groupId>com.alibaba</groupId> <artifactId>druid-spring-boot-starter</artifactId> <version>1.1.10</version> </dependency> <!--Druid--> <depen

springboot 配置DRUID数据源的方法实例分析

本文实例讲述了springboot 配置DRUID数据源的方法.分享给大家供大家参考,具体如下: druid 是阿里开源的数据库连接池. 开发时整合 druid 数据源过程. 1.修改pom.xml <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> </dependency> <dependency> &l

springboot配置多数据源的实例(MongoDB主从)

相信看过上一篇文章的小伙伴已经知道了, 这章要讲的就是MongoDB主从配置. 在这边文章中,你将要学到的是在项目中配置主从数据库,并且兼容其他数据库哟..这些都是博主项目中需要并且比较重要的知识哦~ 好了,废话不多说,直接进主题. 1.pom依赖 <span style="white-space:pre"> </span><dependency> <groupId>org.springframework.boot</groupId

springboot + rabbitmq 如何实现消息确认机制(踩坑经验)

本文收录在个人博客:www.chengxy-nds.top,技术资源共享,一起进步 最近部门号召大伙多组织一些技术分享会,说是要活跃公司的技术氛围,但早就看穿一切的我知道,这 T M 就是为了刷KPI.不过,话说回来这的确是件好事,与其开那些没味的扯皮会,多做技术交流还是很有助于个人成长的. 于是乎我主动报名参加了分享,咳咳咳~ ,真的不是为了那点KPI,就是想和大伙一起学习学习! 这次我分享的是 springboot + rabbitmq 如何实现消息确认机制,以及在实际开发中的一点踩坑经验,

SpringBoot配置Druid数据监控代码实例

druid,一个为监控而生的数据库连接池,提供可视化界面来查看sql执行情况. 1.pom文件引入druid数据源 <!--druid数据源--> <dependency> <groupId>com.alibaba</groupId> <artifactId>druid</artifactId> <version>1.1.8</version> </dependency> 2.新建一个DrruidC

详解nginx basic auth配置踩坑记

nginx的basic auth配置由ngx_http_auth_basic_module模块提供,对HTTP Basic Authentication协议进行了支持,用户可通过该配置设置用户名和密码对web站点进行简单的访问控制. basic auth配置示例: location / { auth_basic "closed site"; auth_basic_user_file conf/htpasswd; } 说明: auth_basic可设置为off或其它字符串,为off时表示

springboot配置druid连接池的方法示例

Druid的简介 Druid首先是一个数据库连接池.Druid是目前最好的数据库连接池,在功能.性能.扩展性方面,都超过其他数据库连接池,包括DBCP.C3P0.BoneCP.Proxool.JBoss DataSource.Druid已经在阿里巴巴部署了超过600个应用,经过一年多生产环境大规模部署的严苛考验.Druid是阿里巴巴开发的号称为监控而生的数据库连接池! Druid的功能 1.替换DBCP和C3P0.Druid提供了一个高效.功能强大.可扩展性好的数据库连接池. 2.可以监控数据库

SpringBoot 集成 Jasypt 对数据库加密以及踩坑

前言 密码安全是非常重要的,因此我们在代码中往往需要对密码进行加密,以此保证密码的安全 加依赖 <!-- jasypt --><dependency> <groupId>com.github.ulisesbocchio</groupId> <artifactId>jasypt-spring-boot-starter</artifactId> <version>3.0.3</version></depend