日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > java >内容正文

java

Java数据库连接池知识汇总(C3P0+DBCP+Druid)

發(fā)布時間:2025/3/21 java 19 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Java数据库连接池知识汇总(C3P0+DBCP+Druid) 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

為什么要使用數(shù)據(jù)庫連接池技術(shù)?

  • 數(shù)據(jù)庫連接池技術(shù)的優(yōu)點

1. 資源重用

由于數(shù)據(jù)庫連接得以重用,避免了頻繁創(chuàng)建,釋放連接引起的大量性能開銷。在減少系統(tǒng)消耗的基礎(chǔ)上,另一方面也增加了系統(tǒng)運行環(huán)境的平穩(wěn)性。

2. 更快的系統(tǒng)反應(yīng)速度

數(shù)據(jù)庫連接池在初始化過程中,往往已經(jīng)創(chuàng)建了若干數(shù)據(jù)庫連接置于連接池中備用。此時連接的初始化工作均已完成。對于業(yè)務(wù)請求處理而言,直接利用現(xiàn)有可用連接,避免了數(shù)據(jù)庫連接初始化和釋放過程的時間開銷,從而減少了系統(tǒng)的響應(yīng)時間。

3. 新的資源分配手段

對于多應(yīng)用共享同一數(shù)據(jù)庫的系統(tǒng)而言,可在應(yīng)用層通過數(shù)據(jù)庫連接池的配置,實現(xiàn)某一應(yīng)用最大可用數(shù)據(jù)庫連接數(shù)的限制,避免某一應(yīng)用獨占所有的數(shù)據(jù)庫資源。

4. 統(tǒng)一的連接管理,避免數(shù)據(jù)庫連接泄漏

在較為完善的數(shù)據(jù)庫連接池實現(xiàn)中,可根據(jù)預(yù)先的占用超時設(shè)定,強制回收被占用連接,從而避免了常規(guī)數(shù)據(jù)庫連接操作中可能出現(xiàn)的資源泄露。

開源的數(shù)據(jù)庫連接池有哪些?

  • JDBC 的數(shù)據(jù)庫連接池使用 javax.sql.DataSource 來表示,DataSource 只是一個接口,該接口通常由服務(wù)器(Weblogic, WebSphere, Tomcat)提供實現(xiàn),也有一些開源組織提供實現(xiàn):

DBCP 是Apache提供的數(shù)據(jù)庫連接池。tomcat服務(wù)器自帶dbcp數(shù)據(jù)庫連接池。速度相對c3p0較快,但因自身存在BUG,Hibernate3已不再提供支持。
C3P0 是一個開源組織提供的一個數(shù)據(jù)庫連接池,速度相對較慢,穩(wěn)定性還可以。hibernate官方推薦使用
Proxool 是sourceforge下的一個開源項目數(shù)據(jù)庫連接池,有監(jiān)控連接池狀態(tài)的功能,穩(wěn)定性較c3p0差一點
BoneCP 是一個開源組織提供的數(shù)據(jù)庫連接池,速度快
Druid 是阿里提供的數(shù)據(jù)庫連接池,據(jù)說是集DBCP 、C3P0 、Proxool 優(yōu)點于一身的數(shù)據(jù)庫連接池,但是速度不確定是否有BoneCP快

  • DataSource 通常被稱為數(shù)據(jù)源,它包含連接池和連接池管理兩個部分,習慣上也經(jīng)常把 DataSource 稱為連接池

  • DataSource用來取代DriverManager來獲取Connection,獲取速度快,同時可以大幅度提高數(shù)據(jù)庫訪問速度。

- 特別注意:

  • 數(shù)據(jù)源和數(shù)據(jù)庫連接不同,數(shù)據(jù)源無需創(chuàng)建多個,它是產(chǎn)生數(shù)據(jù)庫連接的工廠,因此整個應(yīng)用只需要一個數(shù)據(jù)源即可。

  • 當數(shù)據(jù)庫訪問結(jié)束后,程序還是像以前一樣關(guān)閉數(shù)據(jù)庫連接:conn.close();但conn.close()并沒有關(guān)閉數(shù)據(jù)庫的物理連接,它僅僅把數(shù)據(jù)庫連接釋放,歸還給了數(shù)據(jù)庫連接池。

一、C3P0數(shù)據(jù)庫連接池:

  • 以下為官方文檔中的說明:

  • 具體實現(xiàn)步驟:

    1、導(dǎo)入C3P0相關(guān)驅(qū)動(jar包)。

    2、創(chuàng)建c3p0-config.xml文件,代碼實現(xiàn):`

<?xml version="1.0" encoding="UTF-8"?> <c3p0-config><!-- 該參數(shù)為該連接池的名字 --><named-config name="hellc3p0"><!-- 提供獲取連接的4個基本信息 --><property name="driverClass">com.mysql.jdbc.Driver</property><property name="jdbcUrl">jdbc:mysql:///test</property><property name="user">root</property><property name="password">此處應(yīng)寫數(shù)據(jù)庫密碼</property><!-- 進行數(shù)據(jù)庫連接池管理的基本信息 --><!-- 當數(shù)據(jù)庫連接池中的連接數(shù)不夠時,c3p0一次性向數(shù)據(jù)庫服務(wù)器申請的連接數(shù) --><property name="acquireIncrement">5</property><!-- c3p0數(shù)據(jù)庫連接池中初始化時的連接數(shù) --><property name="initialPoolSize">10</property><!-- c3p0數(shù)據(jù)庫連接池維護的最少連接數(shù) --><property name="minPoolSize">10</property><!-- c3p0數(shù)據(jù)庫連接池維護的最多的連接數(shù) --><property name="maxPoolSize">100</property><!-- c3p0數(shù)據(jù)庫連接池最多維護的Statement的個數(shù) --><property name="maxStatements">50</property><!-- 每個連接中可以最多使用的Statement的個數(shù) --><property name="maxStatementsPerConnection">2</property></named-config> </c3p0-config>

3、利用c3p0連接池獲取數(shù)據(jù)庫連接:

官方文檔第二段指出了獲取配置文件c3p0-config.xml的具體實現(xiàn):ComboPooledDataSource cpds = new ComboPooledDataSource(“intergalactoApp”);//自動讀取配置文件中的信息

代碼實現(xiàn):

//獲取c3p0數(shù)據(jù)庫連接池 //靜態(tài)連接池(只需獲取一個連接池即可) private static ComboPooledDataSource cpds = new ComboPooledDataSource("helloc3p0"); //利用連接池獲取數(shù)據(jù)庫連接的方法: public static Connection getConn(){Connection conn = cpds.getConnection();return conn; }

二、DBCP數(shù)據(jù)庫連接池:

  • DBCP介紹:DBCP 是 Apache 軟件基金組織下的開源連接池實現(xiàn),該連接池依賴該組織下的另一個開源系統(tǒng):Common- pool。
  • Tomcat 的連接池正是采用該連接池來實現(xiàn)的。該數(shù)據(jù)庫連接池既可以與應(yīng)用服務(wù)器整合使用,也可由應(yīng)用程 序獨立使用。
  • 數(shù)據(jù)源和數(shù)據(jù)庫連接不同,數(shù)據(jù)源無需創(chuàng)建多個,它是產(chǎn)生數(shù)據(jù)庫連接的工廠,因此整個應(yīng)用只需要一個數(shù)據(jù)
    源即可。
  • 當數(shù)據(jù)庫訪問結(jié)束后,程序還是像以前一樣關(guān)閉數(shù)據(jù)庫連接:conn.close(); 但上面的代碼并沒有關(guān)閉數(shù)據(jù)庫的 物理連接,它僅僅把數(shù)據(jù)庫連接釋放,歸還給了數(shù)據(jù)庫連接池。
  • 配置屬性說明

具體實現(xiàn)步驟:

1、導(dǎo)入DBCP相關(guān)驅(qū)動(jar包)。

Commons-dbcp.jar:連接池的實現(xiàn)
Commons-pool.jar:連接池實現(xiàn)的依賴庫

2、提供一個配置文件【dbcp.properties】,存放在src下:

driverClassName=com.mysql.jdbc.Driver url=jdbc:mysql://localhost:3306/表名 username=root password=數(shù)據(jù)庫連接密碼initialSize=10 。。。等等

3、利用BasicDataSourceFactory類創(chuàng)建一個數(shù)據(jù)庫連接池(有異常try-catch即可):

代碼實現(xiàn):

//靜態(tài)連接池(不寫在方法內(nèi),只需獲取一個連接池即可) private static DataSource source = null; static{InputStream is = JDBCUtils.class.getClassLoader.getResourceAsStream("dbcp.properties");Properties pros = new Properties();pros.load(is);//創(chuàng)建一個數(shù)據(jù)庫連接池://一定是DataSource接口的一個實現(xiàn)類來創(chuàng)建連接池source = BasicDataSourceFactory.createDataSource(pros); } /*** 通過數(shù)據(jù)庫連接池獲取數(shù)據(jù)庫連接的方法*/ public static Connection getConn(){//利用數(shù)據(jù)庫連接池獲取一個數(shù)據(jù)庫連接Connection conn = source.getConnection();return conn; }

三、Druid數(shù)據(jù)庫連接池:

  • Druid介紹:Druid是阿里巴巴開源平臺上一個數(shù)據(jù)庫連接池實現(xiàn),它結(jié)合了C3P0、DBCP、Proxool等DB池的優(yōu)點,同時加入了
    日志監(jiān)控,可以很好的監(jiān)控DB池連接和SQL的執(zhí)行情況,可以說是針對監(jiān)控而生的DB連接池,可以說是目前最好的
    連接池之一。

  • 詳細配置參數(shù)


具體實現(xiàn)步驟:

1、導(dǎo)入Druid相關(guān)驅(qū)動(jar包)。

2、提供一個配置文件【druid.properties】,存放在src下:

driverClassName=com.mysql.jdbc.Driver url=jdbc:mysql:///數(shù)據(jù)庫名 username=root password=連接密碼initialSize=10 maxActive=20 maxWait=1000 filters=wall 。。。等等

3、利用DruidDataSourceFactory類創(chuàng)建一個數(shù)據(jù)庫連接池(有異常try-catch拋出即可):

private static DataSource = null; static{Properties pros = new Properties();InputStream is = JDBCUtils.class.getClassLoader.getResourceAsStream("druid.properties");pros.load(is);//創(chuàng)建一個數(shù)據(jù)庫連接池://一定是DataSource接口的一個實現(xiàn)類來創(chuàng)建連接池source = DruidDataSourceFactory.createDataSource(pros); } /*** 通過數(shù)據(jù)庫連接池獲取數(shù)據(jù)庫連接的方法*/ public static Connection getConn(){Connection conn = source.getConnection();return conn; }

總結(jié)

以上是生活随笔為你收集整理的Java数据库连接池知识汇总(C3P0+DBCP+Druid)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: av网站网址 | 色5月婷婷| 落日余晖图片 | 777777av| 午夜在线观看视频 | 日本特级淫片 | 日本欧美在线 | 国产精品分类 | 国产经典毛片 | 色交视频 | 夜夜嗨av一区二区三区四区 | 涩涩片影院 | 亚洲大片免费 | 樱花动漫无圣光 | 亚洲国产区| 丁香伊人 | 亚洲激情视频在线观看 | 男欢女爱久石 | 国产乱码精品一区二区三区亚洲人 | 激情久久久久久久 | 添女人荫蒂视频 | 日本韩国欧美一区二区 | 在线看污视频 | 国产三级久久久久 | 亚洲欧美一区二区三区 | 狠狠躁日日躁夜夜躁av | 黑人无套内谢中国美女 | 国产欧美在线观看不卡 | 日本全黄裸体片 | 欧美日韩一级大片 | 日韩天堂在线 | 人人射 | 中国三级黄色 | 打开每日更新在线观看 | 找av导航| 永久精品网站 | 综合久久久久 | 国产欧美一区二区三区在线看蜜臀 | 欧美肥老妇视频 | 日韩和欧美的一区二区 | 午夜噜噜 | 男人天堂成人网 | 久久久久性色av无码一区二区 | 韩国毛片一区二区三区 | 韩国精品久久久 | 日本成人一区二区三区 | 九九热精品视频 | 特级西西人体4444xxxx | 亚洲精品自拍视频 | 88av.com| 精品人妻一区二区三区浪潮在线 | 99ri在线 | 天天插天天狠天天透 | 日韩电影一区二区 | 亚洲av无码一区二区三区在线观看 | 久久久久久av无码免费网站下载 | 中文字幕一区二区三区人妻在线视频 | 国产午夜福利精品 | 国产免费播放 | 任我爽在线 | 欧美午夜精品一区二区三区电影 | 亚洲香蕉一区 | 日韩a级在线观看 | 天天cao| 四虎成人网 | 欧美69囗交视频 | 日韩欧美一 | jizz18国产 | 日本熟妇一区二区三区四区 | mm131美女大尺度私密照尤果 | 自拍21区| 9999视频 | 4438x全国最大成人网 | 中国久久久久 | 精品孕妇一区二区三区 | 操一操视频 | 亚洲精品一区二区三区蜜臀 | 97色伦97色伦国产欧美空 | 四虎在线观看 | 黄色一级大片 | 老公吃小头头视频免费观看 | 天天碰视频 | 1000部av| 国产福利视频一区二区 | 少妇被粗大猛进进出出s小说 | 一区二区三区在线观看免费 | 欧美精品黄 | 色婷婷精品 | 少妇高潮毛片色欲ava片 | 国产精品扒开腿做爽爽爽a片唱戏 | 国产乡下妇女做爰视频 | 综合亚洲欧美 | 操比网站 | 韩国一区二区三区四区 | 想要视频在线 | 91精品中文字幕 | 91精品国产精品 | 91久久 | 97色伦图片|