须知:
开启Druid的监控功能,可以在应用运行的过程中,通过监控提供的多维度数据来分析使用数据库的运行情况,从而可以调整程序设计,优化数据库访问的性能。
开启监控功能后,运行应用时,可以通过网址http://ip:port/druid/index.html打开控制台,输入程序中设置的用户名密码即可登录.
在监控后台中,可以实时看到数据库连接池的情况,每一个被执行的sql语句使用的次数和花费的时间,并发数等以及一个URI请求的次数,时间,并发数等。
为分析应用系统访问数据库的情况和性能提供了可靠,详细的原始数据,方便我们在一些细节上优化改造。
1:加pom依赖
<druid.version>1.1.19</druid.version> <dependency> <groupId>com.alibaba</groupId> <artifactId>druid</artifactId> <version>${druid.version}</version> </dependency>
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: 1234 driver-class-name: com.mysql.cj.jdbc.Driver ###################以下为druid增加的配置########################### type: com.alibaba.druid.pool.DruidDataSource # 下面为连接池的补充设置,应用到上面所有数据源中 # 初始化大小,最小,最大 initialSize: 5 minIdle: 5 maxActive: 20 # 配置获取连接等待超时的时间 maxWait: 60000 # 配置间隔多久才进行一次检测,检测需要关闭的空闲连接,单位是毫秒 timeBetweenEvictionRunsMillis: 60000 # 配置一个连接在池中最小生存的时间,单位是毫秒 minEvictableIdleTimeMillis: 300000 validationQuery: SELECT 1 FROM DUAL testWhileIdle: true testOnBorrow: false testOnReturn: false # 打开PSCache,并且指定每个连接上PSCache的大小 poolPreparedStatements: true maxPoolPreparedStatementPerConnectionSize: 20 # 配置监控统计拦截的filters,去掉后监控界面sql无法统计,'wall'用于防火墙,此处是filter修改的地方 filters: stat,wall # 通过connectProperties属性来打开mergeSql功能;慢SQL记录 connectionProperties: druid.stat.mergeSql=true;druid.stat.slowSqlMillis=5000 # 合并多个DruidDataSource的监控数据 useGlobalDataSourceStat: true
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监控 */ @Configuration public class DruidConfiguration { /** * 监控服务器 * @return */ @Bean public ServletRegistrationBean 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"); return servletRegistrationBean; } /** * 过滤器 * @return */ @Bean public FilterRegistrationBean statFilter(){ FilterRegistrationBean filterRegistrationBean =new FilterRegistrationBean(new WebStatFilter()); //添加过滤规则 filterRegistrationBean.addUrlPatterns("/*"); //添加过滤格式 过滤掉这些访问 filterRegistrationBean.addInitParameter("exclusions","*.js,*.gif,*.jpg,*.png,*.css,*.ico,/druid/*"); return filterRegistrationBean; } /** * Druid的控台是监控不了SQL的解决方案 * @return */ @Bean @ConfigurationProperties(prefix = "spring.datasource") public DataSource druidDataSource() { DruidDataSource druidDataSource = new DruidDataSource(); return druidDataSource; } }
4:运行项目 输入网址(ip:端口/druid/index.html)就可以访问了 结果如下
5:遇到的问题
问题一:springboot 使用 druid 不显示sql监控
默认SpringBoot会启动的时候通过反射DruidDataSource的实例来初始化ds,但是druid的其他属性是没有set进去的
所以只要是能把druid的filters属性配置进去就好了,可以直接 @Bean代码启动或者其他方式都可以看到视图