简单用Spring boot druid 搭建SQL监控

在开发项目中,经常有操作数据的动作,为了提高性能操作数据库的时候,有不得不使用数据库连接池。数据库连接池有很多选择,c3p、dhcp、proxool等。

这里来简单研究研究druid连接池,先说说暴露出来的配置点

配置 缺省值 说明
name   配置这个属性的意义在于,如果存在多个数据源,监控的时候 
可以通过名字来区分开来。如果没有配置,将会生成一个名字, 
格式是:"DataSource-" + System.identityHashCode(this)
jdbcUrl   连接数据库的url,不同数据库不一样。例如: 
mysql : jdbc:mysql://10.20.153.104:3306/druid2  
oracle : jdbc:oracle:thin:@10.20.149.85:1521:ocnauto
username   连接数据库的用户名
password   连接数据库的密码。如果你不希望密码直接写在配置文件中, 
可以使用ConfigFilter。详细看这里: 

https://github.com/alibaba/druid/wiki/%E4%BD%BF%E7%94%A8ConfigFilter
driverClassName 根据url自动识别 这一项可配可不配,如果不配置druid会根据url自动识别dbType,然后选择相应的driverClassName
initialSize 0 初始化时建立物理连接的个数。初始化发生在显示调用init方法,或者第一次getConnection时
maxActive 8 最大连接池数量
maxIdle 8 已经不再使用,配置了也没效果
minIdle   最小连接池数量
maxWait   获取连接时最大等待时间,单位毫秒。配置了maxWait之后, 
缺省启用公平锁,并发效率会有所下降, 
如果需要可以通过配置useUnfairLock属性为true使用非公平锁。
poolPreparedStatements false 是否缓存preparedStatement,也就是PSCache。 
PSCache对支持游标的数据库性能提升巨大,比如说oracle。 
在mysql5.5以下的版本中没有PSCache功能,建议关闭掉。
作者在5.5版本中使用PSCache,通过监控界面发现PSCache有缓存命中率记录, 
该应该是支持PSCache。
maxOpenPreparedStatements -1 要启用PSCache,必须配置大于0,当大于0时, 
poolPreparedStatements自动触发修改为true。 
在Druid中,不会存在Oracle下PSCache占用内存过多的问题, 
可以把这个数值配置大一些,比如说100
validationQuery   用来检测连接是否有效的sql,要求是一个查询语句。 
如果validationQuery为null,testOnBorrow、testOnReturn、 
testWhileIdle都不会其作用。
testOnBorrow true 申请连接时执行validationQuery检测连接是否有效,做了这个配置会降低性能。
testOnReturn false 归还连接时执行validationQuery检测连接是否有效,做了这个配置会降低性能
testWhileIdle false 建议配置为true,不影响性能,并且保证安全性。 
申请连接的时候检测,如果空闲时间大于 
timeBetweenEvictionRunsMillis, 
执行validationQuery检测连接是否有效。
timeBetweenEvictionRunsMillis   有两个含义: 
1) Destroy线程会检测连接的间隔时间 
2) testWhileIdle的判断依据,详细看testWhileIdle属性的说明
numTestsPerEvictionRun   不再使用,一个DruidDataSource只支持一个EvictionRun
minEvictableIdleTimeMillis    
connectionInitSqls   物理连接初始化的时候执行的sql
exceptionSorter 根据dbType自动识别 当数据库抛出一些不可恢复的异常时,抛弃连接
filters   属性类型是字符串,通过别名的方式配置扩展插件, 
常用的插件有: 
监控统计用的filter:stat  
日志用的filter:log4j 
防御sql注入的filter:wall
proxyFilters   类型是List, 
如果同时配置了filters和proxyFilters, 
是组合关系,并非替换关系

 

好了那就粗暴一点,直接斗码

首先我们用idea来新建一个web工程,当然也可以用eclipse,也可以用https://start.spring.io/来创建,这里就以idea为例

简单用Spring boot druid 搭建SQL监控_第1张图片

默认点击下一步

简单用Spring boot druid 搭建SQL监控_第2张图片

我这里就不去改包名,项目名称了,也直接默认

简单用Spring boot druid 搭建SQL监控_第3张图片

钩上web里面的web项就好了

简单用Spring boot druid 搭建SQL监控_第4张图片

然后next ----》finish

 

简单用Spring boot druid 搭建SQL监控_第5张图片

然后就会出来一个以demo命名的Spring boot 的web小工程

按此工程结构依次新建对应的Class

简单用Spring boot druid 搭建SQL监控_第6张图片

 

为求简单这里只增加了两个类 DruidConfiguration,DBController

 

pom.xml



	4.0.0
	
		org.springframework.boot
		spring-boot-starter-parent
		2.1.4.RELEASE
		 
	
	com.example
	demo
	0.0.1-SNAPSHOT
	demo
	Demo project for Spring Boot

	
		1.8
	

	
		
			org.springframework.boot
			spring-boot-starter-jdbc
		
		
			com.alibaba
			druid-spring-boot-starter
			1.1.10
		

		
			org.springframework.boot
			spring-boot-starter-web
		
		
			org.mybatis.spring.boot
			mybatis-spring-boot-starter
			2.0.1
		

		
			mysql
			mysql-connector-java
			runtime
		
		
			org.projectlombok
			lombok
			true
		
		
			org.springframework.boot
			spring-boot-starter-test
			test
		
	

	
		
			
				org.springframework.boot
				spring-boot-maven-plugin
			
		
	


上面有几个没有用上的包,我这里就先不管啦,你们可以自己拿掉

这里是application.yml,当然这里生成的是properties文件,idea有可以用以下插件把properties转成yml,当然也可以直接用properties,同时存在相对properties的优先级要高一些

简单用Spring boot druid 搭建SQL监控_第7张图片

server:
    port: 8012
    session:
        timeout: 10
    tomcat:
        uri-encoding: UTF-8
spring:
    datasource:
        # 配置数据源类型
        type:
            com.alibaba.druid.pool.DruidDataSource
        driver-class-name: com.mysql.jdbc.Driver
        url: jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=UTF-8&serverTimezone=UTC
        username: root
        password: root
        # 初始化,最小,最大连接数
        initialSize: 3
        minidle: 3
        maxActive: 18
        # 获取数据库连接等待的超时时间
        maxWait: 60000
        # 配置多久进行一次检测,检测需要关闭的空闲连接 单位毫秒
        timeBetweenEvictionRunsMillis: 60000
        validationQuery: SELECT 1 FROM dual
        # 配置监控统计拦截的filters,去掉后,监控界面的sql无法统计
        filters: stat,wall,log4j

package com.example.demo.config;
/**
 * @Author Justice
 * @Date 2019/4/8 16:17
 * @Version 1.0
 */
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 com.alibaba.druid.support.http.StatViewServlet;
import com.alibaba.druid.support.http.WebStatFilter;


@Configuration
public class DruidConfiguration {




    /**
	 * 注册一个StatViewServlet
	 * @return
	 */
    @Bean
    public ServletRegistrationBean druidStatView(){

       //org.springframework.boot.web.servlet.FilterRegistrationBean提供类的进行注册.
       ServletRegistrationBean servletRegistrationBean = new ServletRegistrationBean(new StatViewServlet(),"/druid/*");

       //添加初始化参数:initParams

       //白名单:
       servletRegistrationBean.addInitParameter("allow","127.0.0.1");

       //IP黑名单 (存在共同时,deny优先于allow) : 如果满足deny的话提示:Sorry, you are not permitted to view this page.
       servletRegistrationBean.addInitParameter("deny","192.168.1.110");

       //登录查看信息的账号密码.
       servletRegistrationBean.addInitParameter("loginUsername","admin");
       servletRegistrationBean.addInitParameter("loginPassword","root");

       //是否能够重置数据.
       servletRegistrationBean.addInitParameter("resetEnable","false");
       return servletRegistrationBean;
    }

    /**
     * 注册一个:filterRegistrationBean
     * @return
     */
    @Bean
    public FilterRegistrationBean druidStatFilter(){
       FilterRegistrationBean filterRegistrationBean = new FilterRegistrationBean(new WebStatFilter());

       //添加过滤规则.
       filterRegistrationBean.addUrlPatterns("/*");

       //添加不需要忽略的格式信息.
       filterRegistrationBean.addInitParameter("exclusions","*.js,*.gif,*.jpg,*.png,*.css,*.ico,/druid/*");

       return filterRegistrationBean;
    }
}
package com.example.demo.controller;
/**
 * @Author Justice
 * @Date 2019/4/8 16:17
 * @Version 1.0
 */

import java.util.List;
import java.util.Map;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
@RestController
@RequestMapping("/dbCon")
public class DbController {
  @Autowired
  private JdbcTemplate jdbcTemplate;
   
  @RequestMapping("/getUsersList")
  public List> getDbType(){
    String sql = "select * from sys_user";
    List> list = jdbcTemplate.queryForList(sql);
    return list;
  }
}

这里就全部打完了

来试验一下

浏览器输入http://127.0.0.1:8012/dbCon/getUsersList

简单用Spring boot druid 搭建SQL监控_第8张图片

查看监控地址    http://127.0.0.1:8012/druid/login.html

简单用Spring boot druid 搭建SQL监控_第9张图片

账号密码代码里面有体现

servletRegistrationBean.addInitParameter("loginUsername","admin");
servletRegistrationBean.addInitParameter("loginPassword","root");

打完

 

 

 

demo下载地址:https://pan.baidu.com/s/1o0UV9YKVtxYyAOrSD-mTHA    提取码:b94k

        csdn下载地址:https://download.csdn.net/download/qq_14926283/11097366

你可能感兴趣的:(Spring,boot,2.x入门到深入)