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

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 运维知识 > 数据库 >内容正文

数据库

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

發(fā)布時(shí)間:2024/3/24 数据库 29 豆豆
生活随笔 收集整理的這篇文章主要介紹了 数据库连接池——DBCP连接池o 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

DBCP

1、什么是DBCP?

DBCP是Apache提供的一款開(kāi)源免費(fèi)的數(shù)據(jù)庫(kù)連接池!

Hibernate3.0之后不再對(duì)DBCP提供支持!因?yàn)镠ibernate聲明DBCP有致命的缺欠!DBCP因?yàn)镠ibernate的這一毀謗很是生氣,并且說(shuō)自己沒(méi)有缺欠。

Hibernate說(shuō):

C3P0是Hibernate3.0默認(rèn)的自帶數(shù)據(jù)庫(kù)連接池,DBCP是Apache開(kāi)發(fā)的數(shù)據(jù)庫(kù)連接池。我們對(duì)這兩種連接池進(jìn)行壓力測(cè)試對(duì)比,發(fā)現(xiàn)在并發(fā)30-0個(gè)用戶以下時(shí),DBCP比C3P0平均時(shí)間快1秒左右。但在并發(fā)400個(gè)用戶時(shí),兩者差不多。

速度上雖然DBCP比C3P0快些,但是有BUG:當(dāng)DBCP建立的數(shù)據(jù)庫(kù)連接,因?yàn)槟撤N原因斷掉后,DBCP將不會(huì)再重新創(chuàng)建新的連接,導(dǎo)致必須重新啟動(dòng)To-mcat才能解決問(wèn)題。DBCP的BUG使我們決定采用C3P0作為數(shù)據(jù)庫(kù)連接池。

dbcp連接池

2、DBCP的使用

DBCP是Apache開(kāi)發(fā)的數(shù)據(jù)庫(kù)連接池,引用的當(dāng)然也是Apache的commons的2個(gè)jar包:

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

和相關(guān)數(shù)據(jù)庫(kù)的驅(qū)動(dòng)包,如mysql的驅(qū)動(dòng)包: mysql-connector-java-5.1.34.jar。這三個(gè)必須得有才能連接數(shù)據(jù)庫(kù)使用連接池。dbcp使用的是裝飾者模式,而c3p0使用的是動(dòng)態(tài)代理。

DBCP中池類(lèi)是: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);? //??初始化連接數(shù)?

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

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

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

? ? ? ?

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

??????

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

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

?? ??? ?/**
?? ??? ? * 連接池內(nèi)部使用四大參數(shù)創(chuàng)建了連接對(duì)象!即mysql驅(qū)動(dòng)提供的Connection
?? ??? ? * 連接池使用mysql的連接對(duì)象進(jìn)行了裝飾,只對(duì)close()方法進(jìn)行了增強(qiáng)!
?? ??? ? * 裝飾之后的Connection的close()方法,用來(lái)把當(dāng)前連接歸還給池!
?? ??? ? */

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

??? }

3、DBCP的配置信息

下面是對(duì)DBCP的配置介紹:

#基本配置

driverClassName=com.mysql.jdbc.Driver

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

username=root

password=123

?

#初始化池大小,即一開(kāi)始池中就會(huì)有10個(gè)連接對(duì)象

默認(rèn)值為0

initialSize=0

?

#最大連接數(shù),如果設(shè)置maxActive=50時(shí),池中最多可以有50個(gè)連接,當(dāng)然這50個(gè)連接中包含被使用的和沒(méi)被使用的(空閑)

#你是一個(gè)包工頭,你一共有50個(gè)工人,但這50個(gè)工人有的當(dāng)前正在工作,有的正在空閑

#默認(rèn)值為8,如果設(shè)置為非正數(shù),表示沒(méi)有限制!即無(wú)限大

maxActive=8

?

#最大空閑連接

#當(dāng)設(shè)置maxIdle=30時(shí),你是包工頭,你允許最多有20個(gè)工人空閑,如果現(xiàn)在有30個(gè)空閑工人,那么要開(kāi)除10個(gè)

#默認(rèn)值為8,如果設(shè)置為負(fù)數(shù),表示沒(méi)有限制!即無(wú)限大

maxIdle=8

?

#最小空閑連接

#如果設(shè)置minIdel=5時(shí),如果你的工人只有3個(gè)空閑,那么你需要再去招2個(gè)回來(lái),保證有5個(gè)空閑工人

#默認(rèn)值為0

minIdle=0

?

#最大等待時(shí)間

#當(dāng)設(shè)置maxWait=5000時(shí),現(xiàn)在你的工作都出去工作了,又來(lái)了一個(gè)工作,需要一個(gè)工人。

#這時(shí)就要等待有工人回來(lái),如果等待5000毫秒還沒(méi)回來(lái),那就拋出異常

#沒(méi)有工人的原因:最多工人數(shù)為50,已經(jīng)有50個(gè)工人了,不能再招了,但50人都出去工作了。

#默認(rèn)值為-1,表示無(wú)限期等待,不會(huì)拋出異常。

maxWait=-1

?

#連接屬性

#就是原來(lái)放在url后面的參數(shù),可以使用connectionProperties來(lái)指定

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

#useServerPrepStmts=trueMySQL開(kāi)啟預(yù)編譯功能

#cachePrepStmts=trueMySQL開(kāi)啟緩存PreparedStatement功能,

#prepStmtCacheSize=50,緩存PreparedStatement的上限

#prepStmtCacheSqlLimit=300,當(dāng)SQL模板長(zhǎng)度大于300時(shí),就不再緩存它

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

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

?

#連接的默認(rèn)提交方式

#默認(rèn)值為true

defaultAutoCommit=true

?

#連接是否為只讀連接

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

#如果是只讀連接,那么你只能用這個(gè)連接來(lái)做查詢

#指定連接為只讀是為了優(yōu)化!這個(gè)優(yōu)化與并發(fā)事務(wù)相關(guān)!

#如果兩個(gè)并發(fā)事務(wù),對(duì)同一行記錄做增、刪、改操作,是不是一定要隔離它們啊?

#如果兩個(gè)并發(fā)事務(wù),對(duì)同一行記錄只做查詢操作,那么是不是就不用隔離它們了?

#如果沒(méi)有指定這個(gè)屬性值,那么是否為只讀連接,這就由驅(qū)動(dòng)自己來(lái)決定了。即Connection的實(shí)現(xiàn)類(lèi)自己來(lái)決定!

defaultReadOnly=false

?

#指定事務(wù)的事務(wù)隔離級(jí)別

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

#如果沒(méi)有指定,那么由驅(qū)動(dòng)中的Connection實(shí)現(xiàn)類(lèi)自己來(lái)決定

defaultTransactionIsolation=REPEATABLE_READ

?

總結(jié)

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

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