Spring Boot 1.5集成Druid

Druid 是阿里巴巴開源平臺上一個數據庫鏈接池實現,是一個高效的數據查詢系統,主要解決的是對於大量的基於時序的數據進行聚合查詢css

環境

SpringBoot 1.5.20 + Mysql5.6 + Druid1.1.6java

DruidDataSource 基本配置參數

配置 默認值 說明
name 配置這個屬性的意義在於,若是存在多個數據源,監控的時候能夠經過名字來區分開來
jdbcUrl 鏈接數據庫的url
username 鏈接數據庫的用戶名
password 鏈接數據庫的密碼
driverClassName 根據url自動識別 這一項可配可不配,若是不配置druid會根據url自動識別dbType,而後選擇相應的driverClassName(建議配置下)
initialSize 0 初始化時創建物理鏈接的個數。初始化發生在顯示調用init方法,或者第一次getConnection時
maxActive 8 最大鏈接池數量
minIdle 最小鏈接池數量
maxWait 獲取鏈接時最大等待時間,單位毫秒
poolPreparedStatements 是否緩存preparedStatement,也就是PSCache。PSCache對支持遊標的數據庫性能提高巨大,好比說oracle。在mysql下建議關閉。
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 申請鏈接的時候檢測,若是空閒時間大於timeBetweenEvictionRunsMillis,執行validationQuery檢測鏈接是否有效。
connectionInitSqls 物理鏈接初始化的時候執行的sql
exceptionSorter 根據dbType自動識別 當數據庫拋出一些不可恢復的異常時,拋棄鏈接
filters 屬性類型是字符串,經過別名的方式配置擴展插件,經常使用的插件有: 監控統計用的filter:stat日誌用的filter:log4j防護sql注入的filter:wall
proxyFilters 類型是List<com.alibaba.druid.filter.Filter>,若是同時配置了filters和proxyFilters,是組合關係,並不是替換關係

引入Druid 依賴

<!-- Druid鏈接池 -->
<dependency>
    <groupId>com.alibaba</groupId>
    <artifactId>druid-spring-boot-starter</artifactId>
    <version>1.1.6</version>
</dependency>

配置 Druid 數據源參數

datasource:
    driver-class-name: com.mysql.jdbc.Driver
    url: jdbc:mysql://localhost:3306/XXX
    username: root
    password: sunday
    type: com.alibaba.druid.pool.DruidDataSource
    # 下面爲鏈接池的補充設置,應用到上面全部數據源中
    # 初始化大小,最小,最大
    initialSize: 5
    minIdle: 5
    maxActive: 20000
    maxWait: 60000
    timeBetweenEvictionRunsMillis: 60000
    minEvictableIdleTimeMillis: 300000
    validationQuery: SELECT 1 FROM DUAL
    testWhileIdle: true
    testOnBorrow: false
    testOnReturn: false
    poolPreparedStatements: true
    #配置監控統計攔截的filters,stat:監控統計、log4j:日誌記錄、wall:防護sql注入
    filters: stat,wall,log4j
    maxPoolPreparedStatementPerConnectionSize: 20
    useGlobalDataSourceStat: true

配置DruidConfig

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;
//import java.util.Arrays;
import java.util.HashMap;
import java.util.Map;

@Configuration
public class DruidConfig {
    /**
     * 將自定義的 Druid 數據源添加到容器中,再也不讓 Spring Boot 自動建立
     * 這樣作的目的是:綁定全局配置文件中的 druid 數據源屬性到 com.alibaba.druid.pool.DruidDataSource
     * 從而讓它們生效
     *
     * @return
     * @ConfigurationProperties(prefix = "spring.datasource"):做用就是將 全局配置文件中 前綴爲 spring.datasource
     * 的屬性值注入到 com.alibaba.druid.pool.DruidDataSource 的同名參數中
     */
    @ConfigurationProperties(prefix = "spring.datasource")
    @Bean
    public DataSource druidDataSource() {
        return new DruidDataSource();
    }
    /**
     * 配置 Druid 監控 之  管理後臺的 Servlet
     * 內置 Servler 容器時沒有web.xml 文件,因此使用 Spring Boot 的註冊 Servlet 方式
     */
    @Bean
    public ServletRegistrationBean statViewServlet() {
        ServletRegistrationBean bean = new ServletRegistrationBean(new StatViewServlet(),
                "/druid/*");
 
        /**
         * loginUsername:Druid 後臺管理界面的登陸帳號
         * loginPassword:Druid 後臺管理界面的登陸密碼
         * allow:Druid 後臺容許誰能夠訪問
         * initParams.put("allow", "localhost"):表示只有本機能夠訪問
         * initParams.put("allow", ""):爲空或者爲null時,表示容許全部訪問
         * deny:Druid 後臺拒絕誰訪問
         * initParams.put("deny", "192.168.43.109");表示禁止此ip訪問
         */
        Map<String, String> initParams = new HashMap<>();
        initParams.put("loginUsername", "admin");
        initParams.put("loginPassword", "P@ssw0rd");
        initParams.put("allow", "");
        /*initParams.put("deny", "192.168.1.20");*/
 
        /** 設置初始化參數*/
        bean.setInitParameters(initParams);
        return bean;
    }
    /**
     * 配置 Druid 監控 之  web 監控的 filter
     * WebStatFilter:用於配置Web和Druid數據源之間的管理關聯監控統計
     */
    @Bean
    public FilterRegistrationBean webStatFilter() {
        FilterRegistrationBean bean = new FilterRegistrationBean();
        bean.setFilter(new WebStatFilter());
 
        /** exclusions:設置哪些請求進行過濾排除掉,從而不進行統計*/
        Map<String, String> initParams = new HashMap<>();
        initParams.put("exclusions", "*.js,*.css,/druid/*");
        bean.setInitParameters(initParams);
        
        /** "/*" 表示過濾全部請求*/
        //bean.setUrlPatterns(Arrays.asList("/*"));
        return bean;
    }
}

訪問

啓動項目訪問:IP:PORT/druid,出現以下界面表明配置成功
在這裏插入圖片描述
在這裏插入圖片描述mysql

問題記錄

  • Failed to bind properties under 'spring.datasource' to javax.sql.DataSource
    在這裏插入圖片描述
    該錯誤爲缺乏log4j依賴,在pom中引入相關依賴便可
<dependency>
    <groupId>log4j</groupId>
    <artifactId>log4j</artifactId>
    <version>1.2.17</version>
</dependency>
  • java.lang.NoClassDefFoundError: org/springframework/boot/autoconfigure/jdbc/metadata/DataSourcePoolMetadataProvider
    在這裏插入圖片描述
    該錯誤爲springboot從1升級到2,應更新druid版本
<dependency>
    <groupId>com.alibaba</groupId>
    <artifactId>druid-spring-boot-starter</artifactId>
    <version>1.1.10</version>
</dependency>
參考博客

Spring Boot 2.x 自定義數據源 DruidDataSource:https://blog.csdn.net/wangmx1993328/article/details/81865153
感謝大佬!!!web

.endspring

相關文章
相關標籤/搜索