Druid连接池

简介

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

引入druid连接池

pom.xml中加入

<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid</artifactId>
<version>1.1.21</version>
</dependency>

application.properties中加入

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

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

代码实战

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



DruidFilter.java

package com.example.config;

import com.alibaba.druid.support.http.StatViewServlet;
import com.alibaba.druid.support.http.WebStatFilter;
import org.springframework.boot.web.servlet.FilterRegistrationBean;
import org.springframework.boot.web.servlet.ServletRegistrationBean;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration; @Configuration
public class DruidFilter { @Bean
public ServletRegistrationBean druidStatView() {
//指定路径进入内置监控页面
ServletRegistrationBean servletRegistrationBean = new ServletRegistrationBean(new StatViewServlet(), "/druid/*"); //IP白名单:
servletRegistrationBean.addInitParameter("allow", "127.0.0.1");
//IP黑名单
servletRegistrationBean.addInitParameter("deny", "192.168.1.73");
//登录查看信息的账号密码.
//servletRegistrationBean.addInitParameter("loginUsername", "admin");
//servletRegistrationBean.addInitParameter("loginPassword", "123456");
//是否能够重置数据.
servletRegistrationBean.addInitParameter("resetEnable", "true");
return servletRegistrationBean;
} @Bean
public FilterRegistrationBean druidWebStatFilter() {
FilterRegistrationBean filterRegistrationBean = new FilterRegistrationBean(new WebStatFilter());
//添加过滤规则.
filterRegistrationBean.addUrlPatterns("/*");
//添加不需要忽略的格式信息.
filterRegistrationBean.addInitParameter("exclusions", "*.js,*.gif,*.jpg,*.png,*.css,*.ico,/druid/*");
return filterRegistrationBean;
} }

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

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

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

效果图如下



恩恩,还自带阿里云的广告,果然是阿里的开源产品

最新文章

  1. Sql Server 2016新功能之 Row-Level Security
  2. spring mvc+ELK从头开始搭建日志平台
  3. js模板
  4. C# Window Form解决播放amr格式音乐问题
  5. tdx api z
  6. C# 将窗口移动到指定位置
  7. shell脚本作为保证PHP脚本不挂掉的守护进程实例
  8. GroupingView点击分组标题不展开,或点击标题部分文字不展开
  9. subversion SVN global ignore pattern
  10. iOS 旋屏问题
  11. IOS开发-OC学习-Foundation框架练习
  12. 情人节,教大家使用css画出一朵玫瑰花。
  13. 使用python实现后台系统的JWT认证(转)
  14. 12563 Jin Ge Jin Qu hao
  15. Python【第三课】 函数基础
  16. 打造适合自己的vim编辑器方法总结
  17. 16个富有创意的HTML5 Canvas动画特效集合
  18. Service discovery
  19. [转]web高级开发的成长之路
  20. leetcode-algorithms-14 Longest Common Prefix

热门文章

  1. nginx基础模块
  2. IntelliJ Idea设置默认换行符 Idea
  3. CRM 公海 回收规则 AI
  4. Andorid SQLite数据库开发基础教程(3)
  5. Linux_CentOS软件安装yum
  6. 实战一:LoadRunner性能测试利器
  7. winform使用委托和事件在窗体之间传值
  8. 23andme的申请流程和注意事项
  9. PAT 甲级 1144 The Missing Number (20 分)(简单,最后一个测试点没过由于开的数组没必要大于N)
  10. PAT 甲级 1065 A+B and C (64bit) (20 分)(溢出判断)*