须知:
开启Druid的监控功能,可以在应用运行的过程中,通过监控提供的多维度数据来分析使用数据库的运行情况,从而可以调整程序设计,优化数据库访问的性能。
开启监控功能后,运行应用时,可以通过网址http://ip:port/druid/index.html打开控制台,输入程序中设置的用户名密码即可登录.
在监控后台中,可以实时看到数据库连接池的情况,每一个被执行的sql语句使用的次数和花费的时间,并发数等以及一个URI请求的次数,时间,并发数等。
为分析应用系统访问数据库的情况和性能提供了可靠,详细的原始数据,方便我们在一些细节上优化改造。
1:加pom依赖
1.1.19
com.alibaba
druid
${druid.version}
View Code
2:配置数据源信息
application.yml文件
spring:
## mysql数据库连接信息
datasource:
url: jdbc:mysql://192.168.3.11:3306/zt_power?useSSL=false&useUnicode=true&characterEncoding=utf-8&allowMultiQueries=true&zeroDateTimeBehavior=convertToNull&transformedBitIsBoolean=true&serverTimezone=UTC
username: zt_dev
password:1234driver-class-name: com.mysql.cj.jdbc.Driver
###################以下为druid增加的配置###########################
type: com.alibaba.druid.pool.DruidDataSource
# 下面为连接池的补充设置,应用到上面所有数据源中
# 初始化大小,最小,最大
initialSize:5minIdle:5maxActive:20# 配置获取连接等待超时的时间
maxWait:60000# 配置间隔多久才进行一次检测,检测需要关闭的空闲连接,单位是毫秒
timeBetweenEvictionRunsMillis:60000# 配置一个连接在池中最小生存的时间,单位是毫秒
minEvictableIdleTimeMillis:300000validationQuery: SELECT1FROM DUAL
testWhileIdle:truetestOnBorrow:falsetestOnReturn:false# 打开PSCache,并且指定每个连接上PSCache的大小
poolPreparedStatements:truemaxPoolPreparedStatementPerConnectionSize:20# 配置监控统计拦截的filters,去掉后监控界面sql无法统计,'wall'用于防火墙,此处是filter修改的地方
filters: stat,wall
# 通过connectProperties属性来打开mergeSql功能;慢SQL记录
connectionProperties: druid.stat.mergeSql=true;druid.stat.slowSqlMillis=5000# 合并多个DruidDataSource的监控数据
useGlobalDataSourceStat:true
View Code
yml文件的配置信息需要springboot版本至少在1.4.1 否则不支持
3:配置监控系统
package com.ztqm.etlproject.config;
import com.alibaba.druid.pool.DruidDataSource;
import com.alibaba.druid.support.http.StatViewServlet;
import com.alibaba.druid.support.http.WebStatFilter;
import org.springframework.boot.context.properties.ConfigurationProperties;
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;
import javax.sql.DataSource;/**
* @author songbin
* @date 20190819
* mysql监控*/@Configurationpublic classDruidConfiguration {/**
* 监控服务器
* @return*/@BeanpublicServletRegistrationBean statViewServlet(){
ServletRegistrationBean servletRegistrationBean=new ServletRegistrationBean(new StatViewServlet(),"/druid/*");//IP白名单
servletRegistrationBean.addInitParameter("allow","192.168.3.107,192.168.3.111,192.168.3.113");//IP黑名单
servletRegistrationBean.addInitParameter("deny","192.168.3.10");//控制台管理用户
servletRegistrationBean.addInitParameter("loginUsername","druid");
servletRegistrationBean.addInitParameter("loginPassword","1234");//是否能够重置数据
servletRegistrationBean.addInitParameter("resetEnable","false");returnservletRegistrationBean;
}/**
* 过滤器
* @return*/@BeanpublicFilterRegistrationBean statFilter(){
FilterRegistrationBean filterRegistrationBean=new FilterRegistrationBean(newWebStatFilter());//添加过滤规则
filterRegistrationBean.addUrlPatterns("/*");//添加过滤格式 过滤掉这些访问
filterRegistrationBean.addInitParameter("exclusions","*.js,*.gif,*.jpg,*.png,*.css,*.ico,/druid/*");returnfilterRegistrationBean;
}/**
* Druid的控台是监控不了SQL的解决方案
* @return*/@Bean
@ConfigurationProperties(prefix= "spring.datasource")publicDataSource druidDataSource() {
DruidDataSource druidDataSource= newDruidDataSource();returndruidDataSource;
}
}
View Code
4:运行项目 输入网址(ip:端口/druid/index.html)就可以访问了 结果如下
5:遇到的问题
问题一:springboot 使用 druid 不显示sql监控
默认SpringBoot会启动的时候通过反射DruidDataSource的实例来初始化ds,但是druid的其他属性是没有set进去的
所以只要是能把druid的filters属性配置进去就好了,可以直接 @Bean代码启动或者其他方式都可以看到视图