1. 程式人生 > >資料庫連線池使用(springboot)

資料庫連線池使用(springboot)

轉自:https://blog.csdn.net/u014209205/article/details/80625963

1. 為什麼要使用資料庫連線池
        使用資料庫連線池主要考慮到程式與資料庫建立連線的效能。建立一個新的資料庫是一個很耗時的過程,在使用完之後,可能還需要不斷的釋放建立的連線,對資源的損耗大。

        而採用資料庫連線池之後,首先就建立了固定數量的資料庫連線,需要用的時候使用即可。當然,這樣做的一個缺點是,可能某些時候完全沒有資料庫請求,但是也保持了資料庫的最小連線數。浪費了資源。不過這種浪費資源相對於完全不採用資料庫連線池還是很有優勢的。

2. 常見的資料庫連線池
        常見的資料庫連線池主要有c3p0,dbcp,tomcat-jdbc-pool,druid,HiKariCP。

        c3p0

        來源於《星球大戰》中的一個機器人名稱,同時這個名稱也包含connection pool中的英文字母。不提供對資料庫的監控。使用時是單執行緒的。

        dbcp

    (database connection pool)是Apache基金會下面的資料庫連線池,同時也是tomcat7.0以前的內建資料庫連線池(tomcat也是apache基金會下)。獨立使用時,需要提供common-dbcp.jar,common-pool.jar,common-connection.jar這三個包。不提供資料庫的監控。使用時是單執行緒的。

        tomcat jdbc pool

        這個是tomcat7.0後新增的資料庫連線池,它相容dbcp。但是比dbcp效能更高。

        druid

        是阿里巴巴開源的資料庫連線池,提供對資料庫的監控,就是為監控而生。它的功能最為全面,可擴充套件性好,具有sql攔截的功能。

        HiKariCP

        是資料庫連線池裡面的後起之秀,出來的比較往,但是效能很好。

       總的來說:效能方面HiKariCP>druid>tomcat jdbc pool>dbcp>c3p0(參考),因為我這邊要選擇可以監控資料庫的,所以選擇了druid。

3. druid配置詳解
        druid的詳細原始碼可以從 https://github.com/alibaba/druid進行下載。

        druid的DataSource基類為:com.alibaba.druid.pool.DruidDataSource。基本的引數配置如下:

4. druid使用demo
        springboot的預設資料來源是org.apache.tomcat.jdbc.pool.DataSource。因為我們在這裡使用的是druid,所以需要修改spring.datasource.type為druid。

        a.新增pom依賴

        <!-- https://mvnrepository.com/artifact/com.alibaba/druid -->
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>druid</artifactId>
            <version>1.1.10</version>
        </dependency>
        b.將與資料庫連線的配置進行修改

        修改前:

spring:
  application:
    name: dev-manager
  datasource:
    driver-class-name: com.mysql.jdbc.Driver
    url: jdbc:mysql://localhost:3306/dev_manage?useUnicode=true&characterEncoding=UTF-8
    username: root
    password: abc12345
        修改後:

spring:
  application:
    name: dev-manager
  datasource:
    # 配置資料來源型別
    type:
      com.alibaba.druid.pool.DruidDataSource
    driver-class-name: com.mysql.jdbc.Driver
    url: jdbc:mysql://localhost:3306/dev_manage?useUnicode=true&characterEncoding=UTF-8
    username: root
    password: abc12345
    # 初始化,最小,最大連線數
    initialSize: 3
    minidle: 3
    maxActive: 18
    # 獲取資料庫連線等待的超時時間
    maxWait: 60000
    # 配置多久進行一次檢測,檢測需要關閉的空閒連線 單位毫秒
    timeBetweenEvictionRunsMillis: 60000
    validationQuery: SELECT 1 FROM dual
    # 配置監控統計攔截的filters,去掉後,監控介面的sql無法統計
    filters: stat,wall,log4j
        c.配置監控統計功能

@Configuration
public class DruidConfiguration {
 
    /**
     * 註冊一個StatViewServlet
     * @return
     */
    @Bean
    public ServletRegistrationBean DruidStatViewServle(){
 
       //org.springframework.boot.context.embedded.ServletRegistrationBean提供類的進行註冊.
       ServletRegistrationBean servletRegistrationBean = new ServletRegistrationBean(new StatViewServlet(),"/druid/*");
 
       //新增初始化引數:initParams
 
       //白名單:
       servletRegistrationBean.addInitParameter("allow","127.0.0.1");
 
       //IP黑名單 (存在共同時,deny優先於allow) : 如果滿足deny的話提示:Sorry, you are not permitted to view this page.
       servletRegistrationBean.addInitParameter("deny","192.168.0.114");
 
       //登入檢視資訊的賬號密碼.
       servletRegistrationBean.addInitParameter("loginUsername","admin");
       servletRegistrationBean.addInitParameter("loginPassword","123456");
 
       //是否能夠重置資料.
       servletRegistrationBean.addInitParameter("resetEnable","false");
       return servletRegistrationBean;
    }
 
    /**
     * 註冊一個:filterRegistrationBean
     * @return
     */
    @Bean
    public FilterRegistrationBean druidStatFilter(){
       FilterRegistrationBean filterRegistrationBean = new FilterRegistrationBean(new WebStatFilter());
 
       //新增過濾規則.
       filterRegistrationBean.addUrlPatterns("/*");
 
       //新增不需要忽略的格式資訊.
       filterRegistrationBean.addInitParameter("exclusions","*.js,*.gif,*.jpg,*.png,*.css,*.ico,/druid/*");
 
       return filterRegistrationBean;
    }
}
5. 訪問監控頁面
        訪問監控頁面http://ip:port/druid/index.html

6. 資料結果對比
        在使用資料庫連線池前後,可以通過在資料庫執行:show full processlist,判斷當前資料庫有多少連線數。

在實際專案中,我在未使用資料庫連線池時,騰訊雲資料庫24小時的監控如下

使用後的連線數

7. 總結
        在實際專案中,資料庫連線池的使用是必不可少的。沒有采用資料庫連線池時,系統是按照資料庫預設的方式保持一定的連線數,將一定的連線數保持在休眠狀態。採用druid資料庫連線池後,正常保持多少連線數,最大保持多少連線數都是可配置的。也有一臺完整的平臺監控整個資料庫。