数据库连接池——DBCP连接池o
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()); ?? ??? ?/** ?????? 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=true,MySQL開(kāi)啟預(yù)編譯功能 #cachePrepStmts=true,MySQL開(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)題。
- 上一篇: 代码是使用计算机的什么,什么是计算机的S
- 下一篇: 设置MySQL复制时,replicate