第六篇:SpringBoot 2.x添加Druid作為數(shù)據庫連接池

整合了一大堆ORM,是時候增加一個連接池了文兑,此處選用了druid作為連接池盒刚,druid是alibaba開源平臺上的一個數(shù)據庫連接池實現(xiàn),對比c3p0绿贞,dbcp加入了對數(shù)據庫的監(jiān)控因块,不知道甩出幾條街的距離,個人推為數(shù)據庫連接池的首選(手動攤手)
這里仍然使用jpa+druid
首先先來看看引入的依賴

    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-jpa</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <!-- 引入druid依賴 -->
        <!-- 此處的引用有兩種 -->
        <!-- 一種是直接引用druid包,另一種是引用starter方式 -->
        <!-- 在此處我引用的是start包,為什么呢籍铁,因為方便呀... -->
        <!-- 注:如果沒有該包,application.properties/application.yml 中將不會出現(xiàn)關于druid的提示 -->
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>druid-spring-boot-starter</artifactId>
            <version>1.1.10</version>
        </dependency>

        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <scope>runtime</scope>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
    </dependencies>

application.properties

#jdbc配置
spring.datasource.driver-class-name=com.mysql.jdbc.Driver
spring.datasource.url=jdbc:mysql:///test
spring.datasource.username=root
spring.datasource.password=root
spring.datasource.type=com.alibaba.druid.pool.DruidDataSource

#連接池的設置
#初始化時建立物理連接的個數(shù)
spring.datasource.druid.initial-size=5
#最小連接池數(shù)量
spring.datasource.druid.min-idle=5
#最大連接池數(shù)量 maxIdle已經不再使用
spring.datasource.druid.max-active=20
#獲取連接時最大等待時間涡上,單位毫秒
spring.datasource.druid.max-wait=60000
#申請連接的時候檢測,如果空閑時間大于timeBetweenEvictionRunsMillis拒名,執(zhí)行validationQuery檢測連接是否有效吩愧。
spring.datasource.druid.test-while-idle=true
#既作為檢測的間隔時間又作為testWhileIdel執(zhí)行的依據
spring.datasource.druid.time-between-eviction-runs-millis=60000
#銷毀線程時檢測當前連接的最后活動時間和當前時間差大于該值時,關閉當前連接
spring.datasource.druid.min-evictable-idle-time-millis=30000
#用來檢測連接是否有效的sql 必須是一個查詢語句
#mysql中為 select 'x'
#oracle中為 select 1 from dual
spring.datasource.druid.validation-query=select 'x'
#申請連接時會執(zhí)行validationQuery檢測連接是否有效,開啟會降低性能,默認為true
spring.datasource.druid.test-on-borrow=false
#歸還連接時會執(zhí)行validationQuery檢測連接是否有效,開啟會降低性能,默認為true
spring.datasource.druid.test-on-return=false
#當數(shù)據庫拋出不可恢復的異常時,拋棄該連接
spring.datasource.druid.exception-sorter=true
#是否緩存preparedStatement,mysql5.5+建議開啟
#spring.datasource.druid.pool-prepared-statements=true
#當值大于0時poolPreparedStatements會自動修改為true
spring.datasource.druid.max-pool-prepared-statement-per-connection-size=20
#配置擴展插件
spring.datasource.druid.filters=stat,wall
#通過connectProperties屬性來打開mergeSql功能增显;慢SQL記錄
spring.datasource.druid.connection-properties=druid.stat.mergeSql=true;druid.stat.slowSqlMillis=500
#合并多個DruidDataSource的監(jiān)控數(shù)據
spring.datasource.druid.use-global-data-source-stat=true
#設置訪問druid監(jiān)控頁的賬號和密碼,默認沒有
#spring.datasource.druid.stat-view-servlet.login-username=admin
#spring.datasource.druid.stat-view-servlet.login-password=admin

#jpa設置
spring.jpa.database=mysql
spring.jpa.show-sql=true
spring.jpa.hibernate.ddl-auto=update

關于jpa的搭建的話雁佳,建議查看這個SpringBoot整合JPA
如果是按照我這種方式的話,那么現(xiàn)在就已經整合完畢了
接來下訪問一下druid的監(jiān)控頁druid

image.png

再看看連接池的配置成功沒有
image.png

以及sql的監(jiān)控
image.png

還記得上面說的druid的兩種配置方式嗎同云,上一種的話糖权,只需要我們寫好配置文件就OK了,而下一種就麻煩一點炸站,我在這里還是把代碼貼上

package com.priv.gabriel;

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;


/**
 * Created with Intellij IDEA.
 *
 * @Author: Gabriel
 * @Date: 2018-10-10
 * @Desciption:
 */

@Configuration

public class DruidConfig {

    @Bean
    @ConfigurationProperties(prefix = "spring.datasource")
    public DataSource druid(){
        return new DruidDataSource();
    }

    @Bean
    public ServletRegistrationBean druidServlet(){
        ServletRegistrationBean bean = new ServletRegistrationBean(new StatViewServlet(),"/druid/*");
        bean.addInitParameter("allow","127.0.0.1");
        bean.addInitParameter("resetEnable","false");
        bean.addInitParameter("loginUsername","admin");
        bean.addInitParameter("loginPassword","admin");
        return bean;
    }

    @Bean
    public FilterRegistrationBean statFilter(){
        FilterRegistrationBean bean = new FilterRegistrationBean(new WebStatFilter());
        bean.addUrlPatterns("/*");
        bean.addInitParameter("exclusions","*.js,*.gif,/druid/*");
        return bean;
    }
}

這種方式需要我們手動的寫上一個servlet以及filter温兼,注意:這里必須要手動的注入一個DruidDataSource而且指定去讀取文件,不然它是不會初始化數(shù)據源的 [這么個問題搞了半個多小時]

好了武契,現(xiàn)在druid的已經整合完畢啦募判。

?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末荡含,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子届垫,更是在濱河造成了極大的恐慌释液,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,378評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件装处,死亡現(xiàn)場離奇詭異误债,居然都是意外死亡,警方通過查閱死者的電腦和手機妄迁,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,356評論 2 382
  • 文/潘曉璐 我一進店門寝蹈,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人登淘,你說我怎么就攤上這事箫老。” “怎么了黔州?”我有些...
    開封第一講書人閱讀 152,702評論 0 342
  • 文/不壞的土叔 我叫張陵,是天一觀的道長流妻。 經常有香客問我牲蜀,道長,這世上最難降的妖魔是什么绅这? 我笑而不...
    開封第一講書人閱讀 55,259評論 1 279
  • 正文 為了忘掉前任涣达,我火速辦了婚禮,結果婚禮上证薇,老公的妹妹穿的比我還像新娘度苔。我一直安慰自己,他們只是感情好棕叫,可當我...
    茶點故事閱讀 64,263評論 5 371
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著奕删,像睡著了一般俺泣。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上完残,一...
    開封第一講書人閱讀 49,036評論 1 285
  • 那天伏钠,我揣著相機與錄音,去河邊找鬼谨设。 笑死熟掂,一個胖子當著我的面吹牛,可吹牛的內容都是我干的扎拣。 我是一名探鬼主播赴肚,決...
    沈念sama閱讀 38,349評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼素跺,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了誉券?” 一聲冷哼從身側響起指厌,我...
    開封第一講書人閱讀 36,979評論 0 259
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎踊跟,沒想到半個月后踩验,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經...
    沈念sama閱讀 43,469評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡商玫,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 35,938評論 2 323
  • 正文 我和宋清朗相戀三年箕憾,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片拳昌。...
    茶點故事閱讀 38,059評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡袭异,死狀恐怖,靈堂內的尸體忽然破棺而出地回,到底是詐尸還是另有隱情扁远,我是刑警寧澤,帶...
    沈念sama閱讀 33,703評論 4 323
  • 正文 年R本政府宣布刻像,位于F島的核電站畅买,受9級特大地震影響,放射性物質發(fā)生泄漏细睡。R本人自食惡果不足惜谷羞,卻給世界環(huán)境...
    茶點故事閱讀 39,257評論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望溜徙。 院中可真熱鬧湃缎,春花似錦、人聲如沸蠢壹。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,262評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽图贸。三九已至蹂季,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間疏日,已是汗流浹背偿洁。 一陣腳步聲響...
    開封第一講書人閱讀 31,485評論 1 262
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留沟优,地道東北人涕滋。 一個月前我還...
    沈念sama閱讀 45,501評論 2 354
  • 正文 我出身青樓,卻偏偏與公主長得像挠阁,于是被迫代替她去往敵國和親宾肺。 傳聞我的和親對象是個殘疾皇子溯饵,可洞房花燭夜當晚...
    茶點故事閱讀 42,792評論 2 345

推薦閱讀更多精彩內容