失眠网,内容丰富有趣,生活中的好帮手!
失眠网 > SpringBoot中使用 Druid 数据库连接池 后台SQL监控无效

SpringBoot中使用 Druid 数据库连接池 后台SQL监控无效

时间:2021-11-21 22:04:50

相关推荐

SpringBoot中使用 Druid 数据库连接池  后台SQL监控无效

首先说下环境和配置, 问题

环境

SpringBoot: 2.3.4.RELEASE

druid-spring-boot-starter: 1.1.22

配置

yaml文件配置

datasource:url: jdbc:mysql://localhost:3306/testdbusername: rootpassword: rootdriver-class-name: com.mysql.cj.jdbc.Drivertype: com.alibaba.druid.pool.DruidDataSourcedruid:# 数据源的其他配置initialSize: 5minIdle: 5maxActive: 20maxWait: 60000timeBetweenEvictionRunsMillis: 60000minEvictableIdleTimeMillis: 300000validationQuery: SELECT 1 FROM DUALtestWhileIdle: truetestOnBorrow: falsetestOnReturn: falsepoolPreparedStatements: true# 配置监控统计拦截的 filters,去掉后监控界面 sql 无法统计,'wall'用于防火墙filters: stat,wallmaxPoolPreparedStatementPerConnectionSize: 20useGlobalDataSourceStat: trueconnectionProperties: druid.stat.mergeSql=true;druid.stat.slowSqlMillis=500

DruidConfiguration 配置类

@Configurationpublic class DruidConfiguration {/*** 配置数据源信息* @return 数据源*/@Bean@ConfigurationProperties(prefix = "spring.datasource")public DataSource druidDataSource() throws SQLException {DruidDataSource dds = new DruidDataSource();dds.setDbType("mysql");//mysql必须小写return dds;}@Beanpublic ServletRegistrationBean<StatViewServlet> servletRegistrationBean(){ServletRegistrationBean<StatViewServlet> servletRegistrationBean = new ServletRegistrationBean<>(new StatViewServlet(),"/druid/*");// IP白名单servletRegistrationBean.addInitParameter("allow","127.0.0.1");//控制台管理用户servletRegistrationBean.addInitParameter("loginUsername","admin");servletRegistrationBean.addInitParameter("loginPassword","admin");//是否能够重置数据servletRegistrationBean.addInitParameter("resetEnable","false");return servletRegistrationBean;}@Beanpublic FilterRegistrationBean<WebStatFilter> statFilter(){FilterRegistrationBean<WebStatFilter> filterRegistrationBean = new FilterRegistrationBean<>(new WebStatFilter());//添加过滤规则filterRegistrationBean.addUrlPatterns("/*");//忽略过滤的格式filterRegistrationBean.addInitParameter("exclusions","*.js,*.gif,*.jpg,*.png,*.css,*.ico,/druid/*");return filterRegistrationBean;}}

问题

解决办法有两

第一种, 修改yaml文件

其实很简单, 就是把所有 druid 为根节点的配置项往上提, 也就是去掉 druid 节点

datasource:url: jdbc:mysql://localhost:3306/xinguanusername: rootpassword: qkm19981013driver-class-name: com.mysql.cj.jdbc.Drivertype: com.alibaba.druid.pool.DruidDataSource# 数据源的其他配置initialSize: 5minIdle: 5maxActive: 20maxWait: 60000timeBetweenEvictionRunsMillis: 60000minEvictableIdleTimeMillis: 300000validationQuery: SELECT 1 FROM DUALtestWhileIdle: truetestOnBorrow: falsetestOnReturn: falsepoolPreparedStatements: true# 配置监控统计拦截的 filters,去掉后监控界面 sql 无法统计,'wall'用于防火墙filters: stat,wallmaxPoolPreparedStatementPerConnectionSize: 20useGlobalDataSourceStat: trueconnectionProperties: druid.stat.mergeSql=true;druid.stat.slowSqlMillis=500

这样就可以监控到SQL语句了

但是这样会有个问题(强迫症患者, 就是 yaml 文件有好多警告, 看着不爽, 我就是 >_<), 如图

第二种, 修改yaml文件和配置类

yaml 文件

datasource:url: jdbc:mysql://localhost:3306/xinguanusername: rootpassword: qkm19981013driver-class-name: com.mysql.cj.jdbc.Drivertype: com.alibaba.druid.pool.DruidDataSource

其实也就是将 其他的配置放到配置类中

DruidConfiguration 配置类

@Configurationpublic class DruidConfiguration {/*** 配置数据源信息* @return 数据源*/@Bean@ConfigurationProperties(prefix = "spring.datasource")public DataSource druidDataSource() throws SQLException {DruidDataSource dds = new DruidDataSource();dds.setInitialSize(5); /* 初始化时建立物理连接的个数 */dds.setMaxActive(20);/* 最大连接池数量 */dds.setMaxWait(60000); /* 获取连接时最大等待时间,单位毫秒 */dds.setMinIdle(8); /* 最小连接池数量 */dds.setTimeBetweenEvictionRunsMillis(60000); /* Destroy线程会检测连接的间隔时间 */dds.setMinEvictableIdleTimeMillis(300000); /* 连接保持空闲而不被驱逐的最小时间 */dds.setValidationQuery("SELECT 1 FROM DUAL"); /* 用来检测连接是否有效的sql,要求是一个查询语句,常用select 'x'。如果validationQuery为null,testOnBorrow、testOnReturn、testWhileIdle都不会起作用。 */dds.setTestWhileIdle(true); /* 建议配置为true,不影响性能,并且保证安全性 */dds.setTestOnBorrow(false); /* 申请连接时执行validationQuery检测连接是否有效,做了这个配置会降低性能 */dds.setTestOnReturn(false); /* 归还连接时执行validationQuery检测连接是否有效,做了这个配置会降低性能 */dds.setPoolPreparedStatements(false); /* 是否缓存preparedStatement,也就是PSCache。PSCache对支持游标的数据库性能提升巨大,比如说oracle。在mysql下建议关闭 */dds.setFilters("stat,wall"); /* 属性类型是字符串,通过别名的方式配置扩展插件,常用的插件有:监控统计用的filter:stat, 日志用的filter:log4j, 防御sql注入的filter:wall */dds.setMaxPoolPreparedStatementPerConnectionSize(50); /* 要启用PSCache,必须配置大于0,当大于0时,poolPreparedStatements自动触发修改为true。在Druid中,不会存在Oracle下PSCache占用内存过多的问题,可以把这个数值配置大一些,比如说100 */dds.setUseGlobalDataSourceStat(true);Properties properties = new Properties();properties.setProperty("druid.stat.mergeSql", "true");properties.setProperty("druid.stat.slowSqlMillis", "100");dds.setConnectProperties(properties);dds.setDbType("mysql");//mysql必须小写return dds;}@Beanpublic ServletRegistrationBean<StatViewServlet> servletRegistrationBean(){ServletRegistrationBean<StatViewServlet> servletRegistrationBean = new ServletRegistrationBean<>(new StatViewServlet(),"/druid/*");// IP白名单servletRegistrationBean.addInitParameter("allow","127.0.0.1");//控制台管理用户servletRegistrationBean.addInitParameter("loginUsername","admin");servletRegistrationBean.addInitParameter("loginPassword","admin");//是否能够重置数据servletRegistrationBean.addInitParameter("resetEnable","false");return servletRegistrationBean;}@Beanpublic FilterRegistrationBean<WebStatFilter> statFilter(){FilterRegistrationBean<WebStatFilter> filterRegistrationBean = new FilterRegistrationBean<>(new WebStatFilter());//添加过滤规则filterRegistrationBean.addUrlPatterns("/*");//忽略过滤的格式filterRegistrationBean.addInitParameter("exclusions","*.js,*.gif,*.jpg,*.png,*.css,*.ico,/druid/*");return filterRegistrationBean;}}

这样的话也可以监控到 SQL 语句, 此篇结束, 谢谢啦, 如果解决了您的问题, 帮忙给个赞哦!

如果觉得《SpringBoot中使用 Druid 数据库连接池 后台SQL监控无效》对你有帮助,请点赞、收藏,并留下你的观点哦!

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。