数据库连接池——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()); ?? ??? ?/** ?????? 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=true,MySQL開啟預編譯功能 #cachePrepStmts=true,MySQL開啟緩存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的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 代码是使用计算机的什么,什么是计算机的S
- 下一篇: 电脑开机卡在android,如何修复它: