SpringBoot学习(五)—— springboot快速整合Druid

喜欢ヅ旅行 2023-06-16 10:47 75阅读 0赞

SpringBoot学习(一)—— idea 快速搭建 Spring boot 框架

SpringBoot学习(二)—— springboot快速整合spring security组件

SpringBoot学习(三)—— springboot快速整合swagger文档

SpringBoot学习(四)—— springboot快速整合Mybatis组件

SpringBoot学习(五)—— springboot快速整合Druid

SpringBoot学习(六)—— springboot快速整合RabbitMQ

SpringBoot学习(七)—— springboot快速整合Redis

Druid连接池

简介

由阿里巴巴开源的druid连接池是目前综合实力最突出的数据库连接池,而且还提供了监控日志功能,能够分析SQL执行情况。

引入druid连接池

pom.xml中加入

  1. <dependency>
  2. <groupId>com.alibaba</groupId>
  3. <artifactId>druid</artifactId>
  4. <version>1.1.21</version>
  5. </dependency>

application.properties中加入

  1. # druid
  2. spring.datasource.type=com.alibaba.druid.pool.DruidDataSource
  3. # 连接池初始化大小,最小,最大
  4. spring.datasource.initialSize=10
  5. spring.datasource.minIdle=10
  6. spring.datasource.maxActive=30
  7. # 连接等待超时时间
  8. spring.datasource.maxWait=60000
  9. # 多久检测需要关闭的空闲连接
  10. spring.datasource.timeBetweenEvictionRunsMillis=60000
  11. # 一个连接在池中最小生存的时间
  12. spring.datasource.minEvictableIdleTimeMillis=300000
  13. # 校验SQL,Oracle配置 spring.datasource.validationQuery=SELECT 1 FROM DUAL,如果不配validationQuery项,则下面三项配置无用
  14. spring.datasource.validationQuery=SELECT 'x'
  15. spring.datasource.testWhileIdle=true
  16. spring.datasource.testOnBorrow=false
  17. spring.datasource.testOnReturn=false
  18. # 打开PSCache,并且指定每个连接上PSCache的大小
  19. spring.datasource.poolPreparedStatements=true
  20. spring.datasource.maxPoolPreparedStatementPerConnectionSize=20
  21. # 配置监控统计拦截的filters,去掉后监控界面sql无法统计,wall用于防火墙
  22. spring.datasource.filters=stat,wall,log4j
  23. # 通过connectProperties属性来打开mergeSql功能;慢SQL记录
  24. spring.datasource.connectionProperties=druid.stat.mergeSql=true;druid.stat.slowSqlMillis=5000
  25. # 合并多个DruidDataSource的监控数据
  26. spring.datasource.useGlobalDataSourceStat=true

注:之前已经配置好了mysql,mybatis,这里没有重复写了

代码实战

新增了一个DruidFilter.java来配置内置的监控

在这里插入图片描述
DruidFilter.java

  1. package com.example.config;
  2. import com.alibaba.druid.support.http.StatViewServlet;
  3. import com.alibaba.druid.support.http.WebStatFilter;
  4. import org.springframework.boot.web.servlet.FilterRegistrationBean;
  5. import org.springframework.boot.web.servlet.ServletRegistrationBean;
  6. import org.springframework.context.annotation.Bean;
  7. import org.springframework.context.annotation.Configuration;
  8. @Configuration
  9. public class DruidFilter {
  10. @Bean
  11. public ServletRegistrationBean druidStatView() {
  12. //指定路径进入内置监控页面
  13. ServletRegistrationBean servletRegistrationBean = new ServletRegistrationBean(new StatViewServlet(), "/druid/*");
  14. //IP白名单:
  15. servletRegistrationBean.addInitParameter("allow", "127.0.0.1");
  16. //IP黑名单
  17. servletRegistrationBean.addInitParameter("deny", "192.168.1.73");
  18. //登录查看信息的账号密码.
  19. //servletRegistrationBean.addInitParameter("loginUsername", "admin");
  20. //servletRegistrationBean.addInitParameter("loginPassword", "123456");
  21. //是否能够重置数据.
  22. servletRegistrationBean.addInitParameter("resetEnable", "true");
  23. return servletRegistrationBean;
  24. }
  25. @Bean
  26. public FilterRegistrationBean druidWebStatFilter() {
  27. FilterRegistrationBean filterRegistrationBean = new FilterRegistrationBean(new WebStatFilter());
  28. //添加过滤规则.
  29. filterRegistrationBean.addUrlPatterns("/*");
  30. //添加不需要忽略的格式信息.
  31. filterRegistrationBean.addInitParameter("exclusions", "*.js,*.gif,*.jpg,*.png,*.css,*.ico,/druid/*");
  32. return filterRegistrationBean;
  33. }
  34. }

注:我之前就已经配置好了spring security,如果在和其他教程一样配置druid的账号密码,会导致输入druid的账号密码后无法跳转进入内置监控页面,我知道有很多方法可以避免,但那都需要额外增加代码来判断绕过,既然spring security已经有了账号权限,何必额外非得给druid单独增加一套账号权限,把 /druid/* 路径配置在spring security中,公用已有的账号权限不更好嘛。所以我没有单独配置。

还有这只是常用的配置,如若需要进一步了解详细的配置

内置监控页面配置详情,Web关联配置详情

效果图如下

在这里插入图片描述
恩恩,还自带阿里云的广告,果然是阿里的开源产品

发表评论

表情:
评论列表 (有 0 条评论,75人围观)

还没有评论,来说两句吧...

相关阅读

    相关 SpringBoot整合Druid

    SpringBoot整合Druid 简介:Druid是阿里巴巴提供的数据库连接池,文本讲解SpringBoot整合Druid。 创建项目 ![在这里插入图片描述]