【SpringBoot】整合阿里 Druid 数据源

编程入门 行业动态 更新时间:2024-10-24 11:26:01

【SpringBoot】整合<a href=https://www.elefans.com/category/jswz/34/1770131.html style=阿里 Druid 数据源"/>

【SpringBoot】整合阿里 Druid 数据源

前言:今年是我的第二个 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 {@Beanpublic 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/practiceusername: rootpassword: 5201314lovedriver-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@Beanpublic 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 关联监控的数据@Beanpublic 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@Beanpublic 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 数据源

本文发布于:2024-03-12 06:23:18,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/1730887.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:阿里   数据源   SpringBoot   Druid

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!