欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

數(shù)據(jù)庫連接池c3p0配置_動力節(jié)點Java學(xué)院整理

 更新時間:2017年08月07日 10:23:02   作者:yixiayizi  
這篇文章主要為大家詳細介紹了數(shù)據(jù)庫連接池c3p0配置的相關(guān)資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下

c3p0的配置方式分為三種,分別是

1.setters一個個地設(shè)置各個配置項
2.類路徑下提供一個c3p0.properties文件
3.類路徑下提供一個c3p0-config.xml文件

1.setters一個個地設(shè)置各個配置項

這種方式最繁瑣,形式一般是這樣:

Properties props = new Properties();

InputStream in = ConnectionManager.class.getResourceAsStream("/c3p0.properties");

props.load(in);

in.close();

ComboPooledDataSource cpds = new ComboPooledDataSource();
cpds.setDriverClass(props.getProperty("driverClass"));
cpds.setJdbcUrl(props.getProperty("jdbcUrl"));
cpds.setUser(props.getProperty("user"));
cpds.setPassword(props.getProperty("password"));

因為繁瑣,所以很不適合采用,于是文檔提供了另外另種方式。

2. 類路徑下提供一個c3p0.properties文件

文件的命名必須是c3p0.properties,里面配置項的格式為:

c3p0.driverClass=com.mysql.jdbc.Driver
c3p0.jdbcUrl=jdbc:mysql://localhost:3306/jdbc
c3p0.user=root
c3p0.password=java

上面只提供了最基本的配置項,其他配置項參照 文檔配置,記得是c3p0.后面加屬性名就是了,最后初始化數(shù)據(jù)源的方式就是這樣簡單:

private static ComboPooledDataSource ds = new ComboPooledDataSource();

public static Connection getConnection() {

 try {
 return ds.getConnection();
 } catch (SQLException e) {
 throw new RuntimeException(e);
 }

}

3.類路徑下提供一個c3p0-config.xml文件

這種方式使用方式與第二種差不多,但是有更多的優(yōu)點
(1).更直觀明顯,很類似hibernate和spring的配置
(2).可以為多個數(shù)據(jù)源服務(wù),提供default-config和named-config兩種配置方式
下面是一個配置模板:

<c3p0-config>
 <default-config> 

 <property name="user">root</property>
 <property name="password">java</property>
 <property name="driverClass">com.mysql.jdbc.Driver</property>
 <property name="jdbcUrl">jdbc:mysql://localhost:3306/jdbc</property>
 <property name="initialPoolSize">10</property>
 <property name="maxIdleTime">30</property>
 <property name="maxPoolSize">100</property>
 <property name="minPoolSize">10</property>
 </default-config>

 <named-config name="myApp">
 <property name="user">root</property>
 <property name="password">java</property>
 <property name="driverClass">com.mysql.jdbc.Driver</property>
 <property name="jdbcUrl">jdbc:mysql://localhost:3306/jdbc</property>
 <property name="initialPoolSize">10</property>
 <property name="maxIdleTime">30</property>
 <property name="maxPoolSize">100</property>
 <property name="minPoolSize">10</property>

 </named-config>

</c3p0-config>

如果要使用default-config則初始化數(shù)據(jù)源的方式與第二種一樣,如果要使用named-config里面配置初始化數(shù)據(jù)源,則只要使用一個帶參數(shù)的ComboPooledDataSource構(gòu)造器就可以了

private static ComboPooledDataSource ds = new ComboPooledDataSource("myApp");
下面整理一下從文檔和網(wǎng)上學(xué)習(xí)到的c3p0配置的理解 (user,password,driverClass,jdbcUrl沒有說的必要)

1.基本配置項

acquireIncrement

default : 3

連接池在無空閑連接可用時一次性創(chuàng)建的新數(shù)據(jù)庫連接數(shù)

initialPoolSize

default : 3

連接池初始化時創(chuàng)建的連接數(shù)

maxPoolSize

default : 15

連接池中擁有的最大連接數(shù),如果獲得新連接時會使連接總數(shù)超過這個值則不會再獲取新連接,而是等待

其他連接釋放,所以這個值有可能會設(shè)計地很大

maxIdleTime

default : 0 單位 s
連接的最大空閑時間,如果超過這個時間,某個數(shù)據(jù)庫連接還沒有被使用,則會斷開掉這個連接
如果為0,則永遠不會斷開連接

minPoolSize
default : 3
連接池保持的最小連接數(shù),后面的maxIdleTimeExcessConnections跟這個配合使用來減輕連接池的負載

2.管理連接池的大小和連接的生存時間

maxConnectionAge

default : 0 單位 s

配置連接的生存時間,超過這個時間的連接將由連接池自動斷開丟棄掉。當(dāng)然正在使用的連接不會馬上斷開,而是等待

它close再斷開。配置為0的時候則不會對連接的生存時間進行限制。

maxIdleTimeExcessConnections

default : 0 單位 s

這個配置主要是為了減輕連接池的負載,比如連接池中連接數(shù)因為某次數(shù)據(jù)訪問高峰導(dǎo)致創(chuàng)建了很多數(shù)據(jù)連接

但是后面的時間段需要的數(shù)據(jù)庫連接數(shù)很少,則此時連接池完全沒有必要維護那么多的連接,所以有必要將

斷開丟棄掉一些連接來減輕負載,必須小于maxIdleTime。配置不為0,則會將連接池中的連接數(shù)量保持到minPoolSize。

為0則不處理。

maxIdleTime也可以歸屬到這一類,前面已經(jīng)寫出來了。

3.配置連接測試:因為連接池中的數(shù)據(jù)庫連接很有可能是維持?jǐn)?shù)小時的連接,很有可能因為數(shù)據(jù)庫服務(wù)器的問題,網(wǎng)絡(luò)問題等導(dǎo)致實際連接已經(jīng)無效,但是連接池里面的連接還是有效的,如果此時獲得連接肯定會發(fā)生異常,所以有必要通過測試連接來確認(rèn)連接的有效性。
下面的前三項用來配置如何對連接進行測試,后三項配置對連接進行測試的時機。

automaticTestTable

default : null

用來配置測試連接的一種方式。配置一個表名,連接池根據(jù)這個表名創(chuàng)建一個空表,

并且用自己的測試sql語句在這個空表上測試數(shù)據(jù)庫連接

這個表只能由c3p0來使用,用戶不能操作,同時用戶配置的preferredTestQuery 將會被忽略。

preferredTestQuery

default : null

用來配置測試連接的另一種方式。與上面的automaticTestTable二者只能選一。

如果要用它測試連接,千萬不要設(shè)為null,否則測試過程會很耗時,同時要保證sql語句中的表在數(shù)據(jù)庫中一定存在。

connectionTesterClassName

default :  com.mchange.v2.c3p0.impl.DefaultConnectionTester

連接池用來支持automaticTestTable和preferredTestQuery測試的類,必須是全類名,就像默認(rèn)的那樣,

可以通過實現(xiàn)UnifiedConnectionTester接口或者繼承AbstractConnectionTester來定制自己的測試方法

idleConnectionTestPeriod

default : 0

用來配置測試空閑連接的間隔時間。測試方式還是上面的兩種之一,可以用來解決MySQL8小時斷開連接的問題。因為它

保證連接池會每隔一定時間對空閑連接進行一次測試,從而保證有效的空閑連接能每隔一定時間訪問一次數(shù)據(jù)庫,將于MySQL

8小時無會話的狀態(tài)打破。為0則不測試。

testConnectionOnCheckin

default : false

如果為true,則在close的時候測試連接的有效性。為了提高測試性能,可以與idleConnectionTestPeriod搭配使用,

配置preferredTestQuery或automaticTestTable也可以加快測試速度。

testConnectionOnCheckout

default : false
性能消耗大。如果為true,在每次getConnection的時候都會測試,為了提高性能,

可以與idleConnectionTestPeriod搭配使用,

配置preferredTestQuery或automaticTestTable也可以加快測試速度。

4.配置PreparedStatement緩存

maxStatements
default : 0
連接池為數(shù)據(jù)源緩存的PreparedStatement的總數(shù)。由于PreparedStatement屬于單個Connection,所以
這個數(shù)量應(yīng)該根據(jù)應(yīng)用中平均連接數(shù)乘以每個連接的平均PreparedStatement來計算。為0的時候不緩存,
同時maxStatementsPerConnection的配置無效。

maxStatementsPerConnection
default : 0
連接池為數(shù)據(jù)源單個Connection緩存的PreparedStatement數(shù),這個配置比maxStatements更有意義,因為
它緩存的服務(wù)對象是單個數(shù)據(jù)連接,如果設(shè)置的好,肯定是可以提高性能的。為0的時候不緩存。

5.重連相關(guān)配置

acquireRetryAttempts

default : 30

連接池在獲得新連接失敗時重試的次數(shù),如果小于等于0則無限重試直至連接獲得成功

acquireRetryDelay

default : 1000 單位ms

連接池在獲得新連接時的間隔時間

breakAfterAcquireFailure
default : false

如果為true,則當(dāng)連接獲取失敗時自動關(guān)閉數(shù)據(jù)源,除非重新啟動應(yīng)用程序。所以一般不用。
個人覺得上述三個沒有更改的必要,但可以將acquireRetryDelay配置地更短一些

6.定制管理Connection的生命周期

connectionCustomizerClassName
default : null
用來定制Connection的管理,比如在Connection acquire 的時候設(shè)定Connection的隔離級別,或者在
Connection丟棄的時候進行資源關(guān)閉,就可以通過繼承一個AbstractConnectionCustomizer來實現(xiàn)相關(guān)

方法,配置的時候使用全類名。有點類似監(jiān)聽器的作用。
例如:

import java.sql.Connection;
import com.mchange.v2.c3p0.AbstractConnectionCustomizer;

public class ConnectionCustomizer extends AbstractConnectionCustomizer{

 @Override
 public void onAcquire(Connection c, String parentDataSourceIdentityToken)
  throws Exception {
 System.out.println("acquire : " + c);
 }
 @Override
 public void onCheckIn(Connection c, String parentDataSourceIdentityToken)
  throws Exception {
 System.out.println("checkin : " + c);
 }
 @Override
 public void onCheckOut(Connection c, String parentDataSourceIdentityToken)
  throws Exception {
 System.out.println("checkout : " + c);
 }
 @Override

 public void onDestroy(Connection c, String parentDataSourceIdentityToken)

  throws Exception {

 System.out.println("destroy : " + c);

 }

}
<property name="connectionCustomizerClassName">liuyun.zhuge.db.ConnectionCustomizer</property>

7.配置未提交的事務(wù)處理

autoCommitOnClose

default : false

連接池在回收數(shù)據(jù)庫連接時是否自動提交事務(wù)

如果為false,則會回滾未提交的事務(wù)

如果為true,則會自動提交事務(wù)

forceIgnoreUnresolvedTransactions

default : false

這個配置強烈不建議為true。
一般來說事務(wù)當(dāng)然由自己關(guān)閉了,為什么要讓連接池來處理這種不細心問題呢?

8.配置debug和回收Connection 一般來說事務(wù)當(dāng)然由自己關(guān)閉了,為什么要讓連接池來處理這種不細心問題呢?

unreturnedConnectionTimeout
default : 0 單位 s
為0的時候要求所有的Connection在應(yīng)用程序中必須關(guān)閉。如果不為0,則強制在設(shè)定的時間到達后回收
Connection,所以必須小心設(shè)置,保證在回收之前所有數(shù)據(jù)庫操作都能夠完成。這種限制減少Connection未關(guān)閉
情況的不是很適用。為0不對connection進行回收,即使它并沒有關(guān)閉。

debugUnreturnedConnectionStackTraces
default : false
如果為true并且unreturnedConnectionTimeout設(shè)為大于0的值,當(dāng)所有被getConnection出去的連接
unreturnedConnectionTimeout時間到的時候,就會打印出堆棧信息。只能在debug模式下適用,因為
打印堆棧信息會減慢getConnection的速度
同第七項一樣的,連接用完當(dāng)然得close了,不要通過unreturnedConnectionTimeout讓連接池來回收未關(guān)閉的連接。

9.其他配置項:因為有些配置項幾乎沒有自己配置的必要,使用默認(rèn)值就好,所以沒有再寫出來

checkoutTimeout
default : 0
配置當(dāng)連接池所有連接用完時應(yīng)用程序getConnection的等待時間。為0則無限等待直至有其他連接釋放
或者創(chuàng)建新的連接,不為0則當(dāng)時間到的時候如果仍沒有獲得連接,則會拋出SQLException

三、示例:

示例采用第二種方式:

1.c3p0.properties:

#驅(qū)動 
c3p0.driverClass=com.mysql.jdbc.Driver 
#地址 
c3p0.jdbcUrl=jdbc:mysql://localhost:3306/jdbc 
#用戶名 
c3p0.user=root 
#密碼 
c3p0.password=lovejava 
#------------------------------- 
#連接池初始化時創(chuàng)建的連接數(shù) 
c3p0.initialPoolSize=3 
#連接池保持的最小連接數(shù) 
c3p0.minPoolSize=3 
#連接池在無空閑連接可用時一次性創(chuàng)建的新數(shù)據(jù)庫連接數(shù),default:3 
c3p0.acquireIncrement=3 
#連接池中擁有的最大連接數(shù),如果獲得新連接時會使連接總數(shù)超過這個值則不會再獲取新連接,而是等待其他連接釋放,所以這個值有可能會設(shè)計地很大,default : 15 
c3p0.maxPoolSize=15 
#連接的最大空閑時間,如果超過這個時間,某個數(shù)據(jù)庫連接還沒有被使用,則會斷開掉這個連接,單位秒 
c3p0.maxIdleTime=100 
#連接池在獲得新連接失敗時重試的次數(shù),如果小于等于0則無限重試直至連接獲得成功 
c3p0.acquireRetryAttempts=30 
#連接池在獲得新連接時的間隔時間 
c3p0.acquireRetryDelay=1000

 2.ConnectionPool

package com.study.pool; 
 
import java.sql.Connection; 
import java.sql.SQLException; 
 
import javax.sql.DataSource; 
 
import com.mchange.v2.c3p0.ComboPooledDataSource; 
 
public class ConnectionPool { 
 private DataSource ds; 
 private static ConnectionPool pool; 
 private ConnectionPool(){ 
 ds = new ComboPooledDataSource(); 
 } 
 public static final ConnectionPool getInstance(){ 
 if(pool==null){ 
  try{ 
  pool = new ConnectionPool(); 
  }catch (Exception e) { 
  e.printStackTrace(); 
  } 
 } 
 return pool; 
 } 
 public synchronized final Connection getConnection() { 
 try { 
  return ds.getConnection(); 
 } catch (SQLException e) { 
  e.printStackTrace(); 
 } 
 return null; 
 } 
 
}

3.PoolThread

package com.study.pool; 
 
import java.sql.Connection; 
import java.sql.PreparedStatement; 
import java.sql.ResultSet; 
import java.sql.SQLException; 
 
public class PoolThread extends Thread { 
 @Override 
 public void run(){ 
 ConnectionPool pool = ConnectionPool.getInstance(); 
 Connection con = null; 
 PreparedStatement stmt= null; 
 ResultSet rs = null; 
 try{ 
  con = pool.getConnection(); 
  stmt = con.prepareStatement("select sysdate as nowtime from dual"); 
  rs = stmt.executeQuery(); 
  while(rs.next()){ 
  System.out.println(Thread.currentThread().getId()+"---------------開始"+rs.getString("nowtime")); 
  } 
 } catch (Exception e) { 
  e.printStackTrace(); 
 }finally{ 
  try { 
  rs.close(); 
  stmt.close(); 
  con.close(); 
  } catch (SQLException e) { 
  e.printStackTrace(); 
  } 
 } 
 System.out.println(Thread.currentThread().getId()+"--------結(jié)束"); 
 } 
}

4.PoolMain

package com.study.pool; 
 
public class PoolMain { 
 
 /** 
 * 數(shù)據(jù)源緩沖池 實例練習(xí) 
 */ 
 public static void main(String[] args) { 
 System.out.println("緩沖池模擬開始"); 
 PoolThread[] threads = new PoolThread[50]; 
 for(int i=0;i<threads.length;i++){ 
  threads[i] = new PoolThread(); 
 } 
 for(int i=0;i<threads.length;i++){ 
  threads[i].start(); 
 } 
 } 
 
}

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 如何使用Java?8中DateTimeFormatter類型轉(zhuǎn)換日期格式詳解

    如何使用Java?8中DateTimeFormatter類型轉(zhuǎn)換日期格式詳解

    這篇文章主要介紹了如何使用Java?8中DateTimeFormatter類型轉(zhuǎn)換日期格式詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-07-07
  • 純java代碼實現(xiàn)抽獎系統(tǒng)

    純java代碼實現(xiàn)抽獎系統(tǒng)

    這篇文章主要為大家詳細介紹了純java代碼實現(xiàn)抽獎系統(tǒng),無連接數(shù)據(jù)庫,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-01-01
  • Redisson分布式信號量RSemaphore的使用超詳細講解

    Redisson分布式信號量RSemaphore的使用超詳細講解

    這篇文章主要介紹了Redisson分布式信號量RSemaphore的使用,基于Redis的Redisson的分布式信號量RSemaphore采用了與java.util.concurrent.Semaphore相似的接口和用法
    2023-02-02
  • 教你用Java Swing實現(xiàn)自助取款機系統(tǒng)

    教你用Java Swing實現(xiàn)自助取款機系統(tǒng)

    今天給大家?guī)淼氖顷P(guān)于JAVA的相關(guān)知識,文章圍繞著如何用Java Swing實現(xiàn)自助取款機系統(tǒng)展開,文中有非常詳細的介紹及代碼示例,需要的朋友可以參考下
    2021-06-06
  • Java 集合的Contains和Remove方法

    Java 集合的Contains和Remove方法

    這篇文章主要介紹了Java 集合Contains和Remove方法的相關(guān)資料,幫助大家更好的理解和學(xué)習(xí)使用Java,感興趣的朋友可以了解下
    2021-02-02
  • Spring Boot集成Swagger接口分類與各元素排序問題

    Spring Boot集成Swagger接口分類與各元素排序問題

    這篇文章主要介紹了Spring Boot集成Swagger接口分類與各元素排序問題,首先我們需要對Swagger中的接口也就是以Controller 層作為第一級梯度進行組織的,Controller在我們實際開發(fā)中,與其他具體接口之間是存在一對多的關(guān)系,本文給大家介紹的非常詳細,需要的朋友參考下吧
    2023-10-10
  • RestTemplate使用之如何設(shè)置請求頭、請求體

    RestTemplate使用之如何設(shè)置請求頭、請求體

    這篇文章主要介紹了RestTemplate使用之如何設(shè)置請求頭、請求體問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-07-07
  • SpringBoot中集成串口通信的項目實踐

    SpringBoot中集成串口通信的項目實踐

    本文主要介紹了SpringBoot中集成串口通信,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-08-08
  • Java跳臺階實現(xiàn)思路和代碼

    Java跳臺階實現(xiàn)思路和代碼

    今天小編就為大家分享一篇關(guān)于Java跳臺階實現(xiàn)思路和代碼,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2019-01-01
  • java Comparator.comparing排序使用示例

    java Comparator.comparing排序使用示例

    本文主要介紹了java Comparator.comparing排序使用示例,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-10-10

最新評論