Druid 是阿里巴巴開源平臺上一個數據庫鏈接池實現,是一個高效的數據查詢系統,主要解決的是對於大量的基於時序的數據進行聚合查詢css
SpringBoot 1.5.20 + Mysql5.6 + Druid1.1.6
java
配置 | 默認值 | 說明 |
---|---|---|
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鏈接池 --> <dependency> <groupId>com.alibaba</groupId> <artifactId>druid-spring-boot-starter</artifactId> <version>1.1.6</version> </dependency>
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
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