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

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

数据库连接池——DBCP连接池o

發布時間:2024/3/24 数据库 35 豆豆
生活随笔 收集整理的這篇文章主要介紹了 数据库连接池——DBCP连接池o 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

DBCP

1、什么是DBCP?

DBCP是Apache提供的一款開源免費的數據庫連接池!

Hibernate3.0之后不再對DBCP提供支持!因為Hibernate聲明DBCP有致命的缺欠!DBCP因為Hibernate的這一毀謗很是生氣,并且說自己沒有缺欠。

Hibernate說:

C3P0是Hibernate3.0默認的自帶數據庫連接池,DBCP是Apache開發的數據庫連接池。我們對這兩種連接池進行壓力測試對比,發現在并發30-0個用戶以下時,DBCP比C3P0平均時間快1秒左右。但在并發400個用戶時,兩者差不多。

速度上雖然DBCP比C3P0快些,但是有BUG:當DBCP建立的數據庫連接,因為某種原因斷掉后,DBCP將不會再重新創建新的連接,導致必須重新啟動To-mcat才能解決問題。DBCP的BUG使我們決定采用C3P0作為數據庫連接池。

dbcp連接池

2、DBCP的使用

DBCP是Apache開發的數據庫連接池,引用的當然也是Apache的commons的2個jar包:

? ? ? ? commons-dbcp-1.4.jar、?commons-pool-1.6.jar

和相關數據庫的驅動包,如mysql的驅動包: mysql-connector-java-5.1.34.jar。這三個必須得有才能連接數據庫使用連接池。dbcp使用的是裝飾者模式,而c3p0使用的是動態代理。

DBCP中池類是:BasicDataSource

??? public void fun1() throws SQLException {

?????? BasicDataSource ds = new BasicDataSource();

?????? ds.setDriverClassName("com.mysql.jdbc.Driver");

?????? ds.setUrl("jdbc:mysql://localhost:3306/mydb1");

?????? ds.setUsername("root");

?????? ds.setPassword("123");

? ? ? ?//?基本配置

?????? ds.setInitialSize(10);? //??初始化連接數?

?????? ds.setMaxActive(20);? //??最大連接數

?????? ds.setMinIdle(2)?;? //??最小空閑連接數

?????? ds.setMaxIdle(10);? //??最大空閑連接數

? ? ? ?

?????? ds.setMaxWait(1000)?;? //??最大等待毫秒數

??????

?????? Connection con = ds.getConnection();

?????? System.out.println(con.getClass().getName());

?? ??? ?/**
?? ??? ? * 連接池內部使用四大參數創建了連接對象!即mysql驅動提供的Connection
?? ??? ? * 連接池使用mysql的連接對象進行了裝飾,只對close()方法進行了增強!
?? ??? ? * 裝飾之后的Connection的close()方法,用來把當前連接歸還給池!
?? ??? ? */

?????? con.close();? ?//? ?關閉連接只是把連接歸還給池!

??? }

3、DBCP的配置信息

下面是對DBCP的配置介紹:

#基本配置

driverClassName=com.mysql.jdbc.Driver

url=jdbc:mysql://localhost:3306/mydb1

username=root

password=123

?

#初始化池大小,即一開始池中就會有10個連接對象

默認值為0

initialSize=0

?

#最大連接數,如果設置maxActive=50時,池中最多可以有50個連接,當然這50個連接中包含被使用的和沒被使用的(空閑)

#你是一個包工頭,你一共有50個工人,但這50個工人有的當前正在工作,有的正在空閑

#默認值為8,如果設置為非正數,表示沒有限制!即無限大

maxActive=8

?

#最大空閑連接

#當設置maxIdle=30時,你是包工頭,你允許最多有20個工人空閑,如果現在有30個空閑工人,那么要開除10

#默認值為8,如果設置為負數,表示沒有限制!即無限大

maxIdle=8

?

#最小空閑連接

#如果設置minIdel=5時,如果你的工人只有3個空閑,那么你需要再去招2個回來,保證有5個空閑工人

#默認值為0

minIdle=0

?

#最大等待時間

#當設置maxWait=5000時,現在你的工作都出去工作了,又來了一個工作,需要一個工人。

#這時就要等待有工人回來,如果等待5000毫秒還沒回來,那就拋出異常

#沒有工人的原因:最多工人數為50,已經有50個工人了,不能再招了,但50人都出去工作了。

#默認值為-1,表示無限期等待,不會拋出異常。

maxWait=-1

?

#連接屬性

#就是原來放在url后面的參數,可以使用connectionProperties來指定

#如果已經在url后面指定了,那么就不用在這里指定了。

#useServerPrepStmts=trueMySQL開啟預編譯功能

#cachePrepStmts=trueMySQL開啟緩存PreparedStatement功能,

#prepStmtCacheSize=50,緩存PreparedStatement的上限

#prepStmtCacheSqlLimit=300,當SQL模板長度大于300時,就不再緩存它

connectionProperties=useUnicode=true;characterEncoding=UTF8;useServerPrepStmts=true;cachePrepStmts=true;

? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? prepStmtCacheSize=50;prepStmtCacheSqlLimit=300

?

#連接的默認提交方式

#默認值為true

defaultAutoCommit=true

?

#連接是否為只讀連接

#Connection有一對方法:setReadOnly(boolean)isReadOnly()

#如果是只讀連接,那么你只能用這個連接來做查詢

#指定連接為只讀是為了優化!這個優化與并發事務相關!

#如果兩個并發事務,對同一行記錄做增、刪、改操作,是不是一定要隔離它們啊?

#如果兩個并發事務,對同一行記錄只做查詢操作,那么是不是就不用隔離它們了?

#如果沒有指定這個屬性值,那么是否為只讀連接,這就由驅動自己來決定了。即Connection的實現類自己來決定!

defaultReadOnly=false

?

#指定事務的事務隔離級別

#可選值:NONE,READ_UNCOMMITTED, READ_COMMITTED, REPEATABLE_READ, SERIALIZABLE

#如果沒有指定,那么由驅動中的Connection實現類自己來決定

defaultTransactionIsolation=REPEATABLE_READ

?

總結

以上是生活随笔為你收集整理的数据库连接池——DBCP连接池o的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。