druid监控数据转存mysql_druid监控mysql程序

须知:

开启Druid的监控功能,可以在应用运行的过程中,通过监控提供的多维度数据来分析使用数据库的运行情况,从而可以调整程序设计,优化数据库访问的性能。

开启监控功能后,运行应用时,可以通过网址http://ip:port/druid/index.html打开控制台,输入程序中设置的用户名密码即可登录.

在监控后台中,可以实时看到数据库连接池的情况,每一个被执行的sql语句使用的次数和花费的时间,并发数等以及一个URI请求的次数,时间,并发数等。

为分析应用系统访问数据库的情况和性能提供了可靠,详细的原始数据,方便我们在一些细节上优化改造。

1:加pom依赖

eba2fc900003c3ede3710b815e916be2b0a.jpg

7745cf2fd22e772868ef1fd2a49a908ec09.jpg

1.1.19

com.alibaba

druid

${druid.version}

View Code

2:配置数据源信息

application.yml文件

b7b61105fa6f719a87a3eeee4dae7392bb5.jpg

621274378342090442886dc30c3847dc4f5.jpg

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:配置监控系统

1ffcc867dce1086ac08b659c9f0563d5ba5.jpg

c65f8e1b660d89a73c318764611664128af.jpg

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)就可以访问了 结果如下

309e4766aa404168dab64fba57c221ef.png

5:遇到的问题

问题一:springboot 使用 druid 不显示sql监控

默认SpringBoot会启动的时候通过反射DruidDataSource的实例来初始化ds,但是druid的其他属性是没有set进去的

所以只要是能把druid的filters属性配置进去就好了,可以直接 @Bean代码启动或者其他方式都可以看到视图

5a9ba257fbf24339c9f03577f0475796.png

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值