中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Java數據庫連接池Tomcat怎么使用

發布時間:2021-11-23 13:30:39 來源:億速云 閱讀:217 作者:iii 欄目:開發技術

這篇文章主要介紹“Java數據庫連接池Tomcat怎么使用”,在日常操作中,相信很多人在Java數據庫連接池Tomcat怎么使用問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”Java數據庫連接池Tomcat怎么使用”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!

前言:

Tomcat 連接池是從 Tomcat 7 開始重新編寫的高并發連接池,用以取代以前 Tomcat 中使用的 DBCP 1 連接池,它可以配置在 Tomcat 中使用,也可以單獨使用。本文主要介紹 Tomcat 連接池的基本使用,文中使用到的軟件版本:Java 1.8.0_191、Tomcat 8.5.72、Spring Boot 2.3.12.RELEASE。

1、配置參數

1.1、基礎配置

參數默認值描述
factory 必須,需要是 org.apache.tomcat.jdbc.pool.DataSourceFactory
type 應該是 javax.sql.DataSource 或 javax.sql.XADataSource

1.2、系統屬性

參數默認值描述
org.apache.tomcat.jdbc.pool.onlyAttemptCurrentClassLoaderfalse是否只使用當前的類加載器(加載該連接池的類加載器)來加載動態類

1.3、一般參數

這些參數和 DBCP 一致,但有些默認值不一樣。

參數默認值描述
defaultAutoCommit驅動的默認值是否自動提交
defaultReadOnly驅動的默認值是否只讀
defaultTransactionIsolation驅動的默認值

默認的事務隔離級別
NONE、READ_COMMITTED、READ_UNCOMMITTED、
REPEATABLE_READ、SERIALIZABLE

defaultCatalog 

默認的 catalog。(目錄,類似于模式名,但比模式名更加抽象;
Oracle,MySQL 不支持,MS SQL Server = 數據庫名)

driverClassName 驅動名稱
url 連接 url
username 用戶名
password 密碼
maxActive100最大活動連接數
maxIdle100最大空閑連接數
minIdle10最小空閑連接數
initialSize10初始連接數
maxWait3000從連接池獲取連接,最大等待時間(秒)
testOnBorrowfalse從連接池獲取連接時,是否驗證有效性;如果驗證失敗,則丟棄該連接。
testOnConnecttrue連接創建時,是否驗證有效性
testOnReturnfalse連接返回連接池時,是否驗證有效性
testWhileIdlefalse連接空閑時,是否驗證有效性
validationQuerynull

連接校驗的查詢sql
如果指定,該 SQL 不需要返回結果,只要不拋 SQLException;如果沒有指定,則通過調用 isValid() 方法進行校驗。

validationQueryTimeout-1校驗查詢的超時時間(秒);非正數表示不啟用該特性。
validatorClassNamenull校驗的類名,需實現 org.apache.tomcat.jdbc.pool.Validator 接口并包含一個無參構造函數。
timeBetweenEvictionRunsMillis5000校驗空閑連接的時間周期(毫秒),不能設為小于 1 秒,非正表示不驗證
minEvictableIdleTimeMillis60000空閑連接至少多長時間(毫秒)后,才會被校驗
removeAbandonedfalse是否刪除泄露的連接
removeAbandonedTimeout60連接泄露的超時時間(秒)
 logAbandonedfalse 連接刪除時是否打印堆棧信息
 connectionProperties null

連接屬性,格式為: [propertyName=property;]*
"user" and "password" 將被除外,所以在此不需要包含這兩個屬性。

1.4、增強參數

參數默認值描述
initSQLnull連接創建時,執行的初始化 SQL
jdbcInterceptorsnull

jdbc 攔截器,需要繼承 org.apache.tomcat.jdbc.pool.JdbcInterceptor;已存在的攔截器:
org.apache.tomcat.jdbc.pool.interceptor.ConnectionState 自動提交、只讀、目錄和事務隔離級別的跟蹤
org.apache.tomcat.jdbc.pool.interceptor.StatementFinalizer statement的跟蹤,在連接返回連接池時關閉它們

validationInterval3000連接校驗的最短間隔(毫秒)
jmxEnabledtrue是否注冊連接池到 JMX
fairQueuetrue 是否使用公平隊列,如果為 true,獲取連接時將按照 "先進先出" 的原則
abandonWhenPercentageFull 0 泄露連接達到 abandonWhenPercentageFull 比例才關閉這些連接,0 表示有泄露連接立馬關閉
maxAge 0連接最大存活時間;在從連接池獲取連接和連接返回連接池時進行該項檢測,如果 now - time-when-connected > maxAge,則關閉該連接;0 表示不進行該項檢測。
useEqualstrue  是否使用 String.equals 來判斷 ProxyConnection 是否相等
suspectTimeout0 和 removeAbandonedTimeout 類似,但該設置只是打印日志并不刪除連接;大于 0 才生效。
rollbackOnReturnfalse連接在返回連接池時是否自動回滾事務。
commitOnReturnfalse連接在返回連接池時是否自動提交事務;如果 rollbackOnReturn==true 則忽略該參數。
alternateUsernameAllowedfalse從連接池獲取連接時是否允許設置新的憑證。默認情況下,連接池會忽略 DataSource.getConnection(username,password) 的調用,直接返回一個已創建的連接;如果要使用不同的憑證來獲取連接,即 DataSource.getConnection(username,password) 生效,可把該參數設為 true。
dataSourcenull 設置數據源,連接池將從該數據源獲取連接
dataSourceJNDInull 數據源的 jndi
useDisposableConnectionFacadetrue是否使用連接外觀;設置為 true 可以防止連接關閉后的重復使用。
logValidationErrorsfalse是否記錄校驗的錯誤
propagateInterruptStatefalse是否傳播線程中斷狀態
ignoreExceptionOnPreLoadfalse是否忽略創建連接時的錯誤
useStatementFacadetrue如果希望使用包裝 statement,以便在設置了 statement 代理時,在已關閉的 statement 上調用 equals() and hashCode() 方法,需將此設置為 true。

詳細的說明可以參考官網文檔:https://tomcat.apache.org/tomcat-8.5-doc/jdbc-pool.html

2、使用

2.1、直接使用

2.1.1、引入依賴
<dependency>

    <groupId>org.apache.tomcat</groupId>

    <artifactId>tomcat-jdbc</artifactId>

    <version>8.5.72</version>

</dependency>
2.1.2、使用例子
package com.abc.demo.general.dbpool;

import org.apache.tomcat.jdbc.pool.DataSource;

import org.apache.tomcat.jdbc.pool.PoolProperties;

import java.sql.Connection;

import java.sql.ResultSet;

import java.sql.SQLException;

import java.sql.Statement;

public class TomcatPoolCase {

    public static void main(String[] args) {

        PoolProperties poolProperties = new PoolProperties();

        poolProperties.setName("Tomcat連接池");

        poolProperties.setUrl("jdbc:mysql://10.40.9.11:3306/mydb?useUnicode=true&characterEncoding=UTF-8");

        poolProperties.setDriverClassName("com.mysql.cj.jdbc.Driver");

        poolProperties.setUsername("root");

        poolProperties.setPassword("123456");

        poolProperties.setJmxEnabled(true);

        poolProperties.setTestWhileIdle(false);

        poolProperties.setTestOnBorrow(true);

        poolProperties.setValidationQuery("SELECT 1");

        poolProperties.setTestOnReturn(false);

        poolProperties.setValidationInterval(30000);

        poolProperties.setTimeBetweenEvictionRunsMillis(30000);

        poolProperties.setMaxActive(100);

        poolProperties.setInitialSize(10);

        poolProperties.setMaxWait(10000);

        poolProperties.setRemoveAbandonedTimeout(60);

        poolProperties.setMinEvictableIdleTimeMillis(30000);

        poolProperties.setMinIdle(10);

        poolProperties.setLogAbandoned(true);

        poolProperties.setRemoveAbandoned(true);

        poolProperties.setJdbcInterceptors(

                "org.apache.tomcat.jdbc.pool.interceptor.ConnectionState;" +

                "org.apache.tomcat.jdbc.pool.interceptor.StatementFinalizer");

        DataSource datasource = new DataSource();

        datasource.setPoolProperties(poolProperties);

        Connection connection = null;

        try {

            connection = datasource.getConnection();

            Statement st = connection.createStatement();

            ResultSet rs = st.executeQuery("select version()");

            if (rs.next()) {

                System.out.println(rs.getString(1));

            }

        } catch (SQLException e) {

            e.printStackTrace();

        } finally {

            close(connection);

        }

        //實際使用中一般是在應用啟動時初始化數據源,應用從數據源中獲取連接;并不會關閉數據源。

        datasource.close();

    }

    private static void close(Connection connection) {

        if (connection != null) {

            try {

                connection.close();

            } catch (SQLException e) {

                e.printStackTrace();

            }

        }

    }

}

2.2、作為資源配置在 Tomcat 中

先把對應數據庫的驅動包拷貝到 Tomcat 或應用的 lib 目錄下,然后在 content.xml 中配置資源,

content.xml 可以在如下位置:

  • conf/context.xml:針對所有的應用

  • conf/Catalina/localhost:針對單個應用,適合在 Tomcat 外部部署應用

  • {應用}/META-INFcontext.xml:針對單個應用

配置資源的例子如下:

<Resource name="jdbc/testDb"

    auth="Container"

    type="javax.sql.DataSource"

    factory="org.apache.tomcat.jdbc.pool.DataSourceFactory"

    testWhileIdle="true"

    testOnBorrow="true"

    testOnReturn="false"

    validationQuery="SELECT 1"

    validationInterval="30000"

    timeBetweenEvictionRunsMillis="30000"

    maxActive="20"

    maxIdle="20"

    minIdle="5"

    maxWait="10000"

    initialSize="5"

    removeAbandonedTimeout="60"

    removeAbandoned="true"

    logAbandoned="true"

    minEvictableIdleTimeMillis="30000"

    jmxEnabled="true"

    jdbcInterceptors="org.apache.tomcat.jdbc.pool.interceptor.ConnectionState;

    org.apache.tomcat.jdbc.pool.interceptor.StatementFinalizer"

    username="root"

    password="123456"

    driverClassName="com.mysql.cj.jdbc.Driver"

    url="jdbc:mysql://10.40.9.11:3306/mydb?useUnicode=true&amp;characterEncoding=UTF-8" />

可以通過 jndi 來查找該資源,這里通過 jsp 來演示查找方法:

<%@ page language="java" contentType="text/html; charset=utf-8" pageEncoding="UTF-8"%>

<%@ page import="javax.naming.Context,

                javax.naming.InitialContext,

                javax.sql.DataSource,

                java.sql.*"%>

<%

    Connection connection = null;

    try {

        InitialContext initialContext = new InitialContext();

        Context context = (Context) initialContext.lookup("java:comp/env");

        DataSource dataSource = (DataSource)context.lookup("jdbc/testDb");

        connection = dataSource.getConnection();

        Statement st = connection.createStatement();

        ResultSet rs = st.executeQuery("select version()");

        if (rs.next()) {

            System.out.println(rs.getString(1));

        }

    } catch (Exception e) {

        e.printStackTrace();

    } finally {

        if (connection != null) {

            try {

                connection.close();

            } catch (SQLException e) {

                e.printStackTrace();

            }

        }

    }

%>

<html>

    <body>

        <h4>通過 jndi 查找數據源并獲取數據庫的版本信息</h4>

    </body>

</html>

3.2、在 SpringBoot 中使用

3.1.1、引入依賴
<parent>

    <groupId>org.springframework.boot</groupId>

    <artifactId>spring-boot-starter-parent</artifactId>

    <version>2.3.12.RELEASE</version>

    <relativePath />

</parent>

<dependencies>

    <dependency>

        <groupId>org.springframework.boot</groupId>

        <artifactId>spring-boot-starter-web</artifactId>

    </dependency>

    <dependency>

        <groupId>org.springframework</groupId>

        <artifactId>spring-jdbc</artifactId>

    </dependency>

    <dependency>

        <groupId>org.apache.tomcat</groupId>

        <artifactId>tomcat-jdbc</artifactId>

        <version>8.5.72</version>

    </dependency>

    <dependency>

        <groupId>mysql</groupId>

        <artifactId>mysql-connector-java</artifactId>

    </dependency>

</dependencies>
3.1.2、單數據源

application.yml 配置:

spring:

  datasource:

    tomcat-pool:

      name: Tomcat連接池

      url: jdbc:mysql://10.40.9.11:3306/mydb?useUnicode=true&characterEncoding=UTF-8

      driver-class-name: com.mysql.cj.jdbc.Driver

      username: root

      password: 123456

      test-while-idle: true

      test-on-borrow: true

      validation-query: select 1

      test-on-return: false

      validation-interval: 30000

      time-between-eviction-runs-millis: 30000

      max-active: 100

      initial-size: 10

      max-wait: 10000

      remove-abandoned-timeout: 60

      min-evictable-idle-time-millis: 30000

      min-idle: 10

      log-abandoned: true

      remove-abandoned: true

      jdbc-interceptors: org.apache.tomcat.jdbc.pool.interceptor.ConnectionState;org.apache.tomcat.jdbc.pool.interceptor.StatementFinalizer

數據源配置類:

package com.abc.demo.config;

import org.springframework.boot.context.properties.ConfigurationProperties;

import org.springframework.boot.jdbc.DataSourceBuilder;

import org.springframework.context.annotation.Bean;

import org.springframework.context.annotation.Configuration;

import javax.sql.DataSource;

@Configuration

public class DataSourceConfig {

    @Bean("dataSource")

    @ConfigurationProperties(prefix = "spring.datasource.tomcat-pool")

    public DataSource dataSource() {

        return DataSourceBuilder.create().type(org.apache.tomcat.jdbc.pool.DataSource.class).build();

    }

}

使用:

@Autowired

private DataSource dataSource;
3.1.3、多數據源

application.yml 配置:

spring:

  datasource:

    tomcat-pool:

      db1:

        name: Tomcat連接池

        url: jdbc:mysql://10.40.9.11:3306/mydb?useUnicode=true&characterEncoding=UTF-8

        driver-class-name: com.mysql.cj.jdbc.Driver

        username: root

        password: 123456

        test-while-idle: true

        test-on-borrow: true

        validation-query: select 1

        test-on-return: false

        validation-interval: 30000

        time-between-eviction-runs-millis: 30000

        max-active: 100

        initial-size: 10

        max-wait: 10000

        remove-abandoned-timeout: 60

        min-evictable-idle-time-millis: 30000

        min-idle: 10

        log-abandoned: true

        remove-abandoned: true

        jdbc-interceptors: org.apache.tomcat.jdbc.pool.interceptor.ConnectionState;org.apache.tomcat.jdbc.pool.interceptor.StatementFinalizer

      db2:

        name: Tomcat連接池

        url: jdbc:mysql://10.110.74.187:3306/egmp?useUnicode=true&characterEncoding=UTF-8

        driver-class-name: com.mysql.cj.jdbc.Driver

        username: root

        password: InsYR0ot187!

        test-while-idle: true

        test-on-borrow: true

        validation-query: select 1

        test-on-return: false

        validation-interval: 30000

        time-between-eviction-runs-millis: 30000

        max-active: 100

        initial-size: 10

        max-wait: 10000

        remove-abandoned-timeout: 60

        min-evictable-idle-time-millis: 30000

        min-idle: 10

        log-abandoned: true

        remove-abandoned: true

        jdbc-interceptors: org.apache.tomcat.jdbc.pool.interceptor.ConnectionState;org.apache.tomcat.jdbc.pool.interceptor.StatementFinalizer

數據源配置類:

package com.abc.demo.config;

import org.springframework.boot.context.properties.ConfigurationProperties;

import org.springframework.boot.jdbc.DataSourceBuilder;

import org.springframework.context.annotation.Bean;

import org.springframework.context.annotation.Configuration;

import javax.sql.DataSource;

@Configuration

public class DataSourceConfig {

    @Bean("dataSource1")

    @ConfigurationProperties(prefix = "spring.datasource.tomcat-pool.db1")

    public DataSource dataSource1() {

        return DataSourceBuilder.create().type(org.apache.tomcat.jdbc.pool.DataSource.class).build();

    }

    @Bean("dataSource2")

    @ConfigurationProperties(prefix = "spring.datasource.tomcat-pool.db2")

    public DataSource dataSource2() {

        return DataSourceBuilder.create().type(org.apache.tomcat.jdbc.pool.DataSource.class).build();

    }

}

使用:

@Autowired

@Qualifier("dataSource1")

private DataSource dataSource1;

@Autowired

@Qualifier("dataSource2")

private DataSource dataSource2;

到此,關于“Java數據庫連接池Tomcat怎么使用”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

沭阳县| 锦州市| 宁武县| 富阳市| 河源市| 化德县| 闻喜县| 兴宁市| 永安市| 海伦市| 昌江| 石河子市| 旬阳县| 呈贡县| 茶陵县| 襄垣县| 大厂| 渑池县| 沭阳县| 景东| 大埔县| 香河县| 临高县| 铁力市| 临澧县| 武定县| 西城区| 商河县| 开阳县| 萨嘎县| 巴楚县| 平利县| 武定县| 屏山县| 莱阳市| 利津县| 鞍山市| 花莲县| 钟山县| 辉县市| 磴口县|