生活随笔
收集整理的這篇文章主要介紹了
DruidDataSource
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
DruidDataSource
自定義數據源DRUID
-
使用手冊網址:https://www.bookstack.cn/read/Druid/2fa0c5cdf8a9e77e.md
-
Github項目地址: https://github.com/alibaba/druid
-
Druid是阿里巴巴開源平臺上的一個數據源連接池的實現,結合了C3P0、DBCP、PROXOOL等DB池的優點,同時加入了日志監控
-
Druid可以很好的監控DB連接池和SQL執行情況,天生就是針對監控而生的DB連接池。
-
springboot2.0以上默認使用Hikari數據源。
-
DruidDataSource 是阿里寫出來的一個數據源, 它不僅可以獲取數據庫連接,還把這些數據庫連接管理了起來,也就是所謂的數據庫連接池。這樣的話,當通過該數據源獲取數據庫連接的時候,如果數據庫連接池里有可以使用的連接,那么就直接返回該連接,就省的每次獲取數據庫連接都要創建了。
-
引入數據源
<dependency><groupId>com.alibaba
</groupId><artifactId>druid
</artifactId><version>1.0.16
</version>
</dependency>
<dependency><groupId>log4j
</groupId><artifactId>log4j
</artifactId><version>1.2.17
</version>
</dependency>
spring.datasource.type=com.alibaba.druid.pool.DruidDataSource
spring:datasource:username: root
password: 123456url: jdbc
:mysql
://localhost
:3306/dataxm
?serverTimezone=UTC
&useUnicode=true&characterEncoding=utf-8driver-class-name: com.mysql.cj.jdbc.Driver
type: com.alibaba.druid.pool.DruidDataSource
initialSize: 5minIdle: 5maxActive: 20maxWait: 60000timeBetweenEvictionRunsMillis: 60000minEvictableIdleTimeMillis: 300000validationQuery: SELECT 1 FROM DUAL
testWhileIdle: truetestOnBorrow: falsetestOnReturn: falsepoolPreparedStatements: truefilters: stat
,wall
,log4j
maxPoolPreparedStatementPerConnectionSize: 20useGlobalDataSourceStat: trueconnectionionProperties: druid.stat.mergeSql=true;druid.stat.slowSqlMillis=500
package com.qiumin.springbootxm.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;
import java.util.HashMap;@Configuration
public class druidConfig
{@ConfigurationProperties(prefix
= "spring.datasource") @Beanpublic DataSource druidDataSource(){return new DruidDataSource();}@Beanpublic ServletRegistrationBean statViewServlet(){ServletRegistrationBean<StatViewServlet> bean
=new ServletRegistrationBean<>(new StatViewServlet(),"/druid/*");HashMap<String, String> initParameters
= new HashMap<>();initParameters
.put("loginUsername","admin");initParameters
.put("loginPassword","123456");initParameters
.put("allow","");bean
.setInitParameters(initParameters
);return bean
;}public FilterRegistrationBean webstatFilter(){FilterRegistrationBean bean
= new FilterRegistrationBean();bean
.setFilter(new WebStatFilter());HashMap<String, String> initParameters
= new HashMap<>();initParameters
.put("exclusions","*.js,*.css,/druid/*");bean
.setInitParameters(initParameters
);return bean
;}
}
執行一個SQL語句后訪問 http://localhost:8080/druid
**在druid后臺SQL監控頁面記錄了詳細的SQL的執行情況
結論:
- 必須在方法上加上 @Bean注解,讓spring容器托管。
- 訪問監控頁面的url:http://localhost:8080/druid會進入一個登錄頁面,用上面配置的用戶和密碼登錄即可。
- druid需要log4j的支持。
- 使用map初始化變量。
qiumin
總結
以上是生活随笔為你收集整理的DruidDataSource的全部內容,希望文章能夠幫你解決所遇到的問題。
如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。