SpringBoot學習(五)—— springboot快速整合Druid

Druid鏈接池

簡介

由阿里巴巴開源的druid鏈接池是目前綜合實力最突出的數據庫鏈接池,並且還提供了監控日誌功能,可以分析SQL執行狀況。css

引入druid鏈接池

pom.xml中加入java

<dependency>
    <groupId>com.alibaba</groupId>
    <artifactId>druid</artifactId>
    <version>1.1.21</version>
</dependency>

application.properties中加入mysql

# druid
spring.datasource.type=com.alibaba.druid.pool.DruidDataSource

# 鏈接池初始化大小,最小,最大
spring.datasource.initialSize=10
spring.datasource.minIdle=10
spring.datasource.maxActive=30
# 鏈接等待超時時間
spring.datasource.maxWait=60000
# 多久檢測須要關閉的空閒鏈接
spring.datasource.timeBetweenEvictionRunsMillis=60000
# 一個鏈接在池中最小生存的時間
spring.datasource.minEvictableIdleTimeMillis=300000
# 校驗SQL,Oracle配置 spring.datasource.validationQuery=SELECT 1 FROM DUAL,若是不配validationQuery項,則下面三項配置無用
spring.datasource.validationQuery=SELECT 'x'
spring.datasource.testWhileIdle=true
spring.datasource.testOnBorrow=false
spring.datasource.testOnReturn=false
# 打開PSCache,而且指定每一個鏈接上PSCache的大小
spring.datasource.poolPreparedStatements=true
spring.datasource.maxPoolPreparedStatementPerConnectionSize=20
# 配置監控統計攔截的filters,去掉後監控界面sql沒法統計,wall用於防火牆
spring.datasource.filters=stat,wall,log4j
# 經過connectProperties屬性來打開mergeSql功能;慢SQL記錄
spring.datasource.connectionProperties=druid.stat.mergeSql=true;druid.stat.slowSqlMillis=5000
# 合併多個DruidDataSource的監控數據
spring.datasource.useGlobalDataSourceStat=true

注:以前已經配置好了mysql,mybatis,這裏沒有重複寫了git

代碼實戰

新增了一個DruidFilter.java來配置內置的監控github

在這裏插入圖片描述
DruidFilter.javaweb

package com.example.config;

import com.alibaba.druid.support.http.StatViewServlet;
import com.alibaba.druid.support.http.WebStatFilter;
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;

@Configuration
public class DruidFilter {

    @Bean
    public ServletRegistrationBean druidStatView() {
        //指定路徑進入內置監控頁面
        ServletRegistrationBean servletRegistrationBean = new ServletRegistrationBean(new StatViewServlet(), "/druid/*");

        //IP白名單:
        servletRegistrationBean.addInitParameter("allow", "127.0.0.1");
        //IP黑名單
        servletRegistrationBean.addInitParameter("deny", "192.168.1.73");
        //登陸查看信息的帳號密碼.
        //servletRegistrationBean.addInitParameter("loginUsername", "admin");
        //servletRegistrationBean.addInitParameter("loginPassword", "123456");
        //是否可以重置數據.
        servletRegistrationBean.addInitParameter("resetEnable", "true");
        return servletRegistrationBean;
    }

    @Bean
    public FilterRegistrationBean druidWebStatFilter() {
        FilterRegistrationBean filterRegistrationBean = new FilterRegistrationBean(new WebStatFilter());
        //添加過濾規則.
        filterRegistrationBean.addUrlPatterns("/*");
        //添加不須要忽略的格式信息.
        filterRegistrationBean.addInitParameter("exclusions", "*.js,*.gif,*.jpg,*.png,*.css,*.ico,/druid/*");
        return filterRegistrationBean;
    }

}

注:我以前就已經配置好了spring security,若是在和其餘教程同樣配置druid的帳號密碼,會致使輸入druid的帳號密碼後沒法跳轉進入內置監控頁面,我知道有不少方法能夠避免,但那都須要額外增長代碼來判斷繞過,既然spring security已經有了帳號權限,何須額外非得給druid單獨增長一套帳號權限,把 /druid/* 路徑配置在spring security中,公用已有的帳號權限不更好嘛。因此我沒有單獨配置。spring

還有這只是經常使用的配置,如若須要進一步瞭解詳細的配置sql

內置監控頁面配置詳情Web關聯配置詳情數據庫

效果圖以下mybatis

在這裏插入圖片描述恩恩,還自帶阿里雲的廣告,果真是阿里的開源產品

相關文章
相關標籤/搜索