Hibernate支持第三方的連接池,官方推薦的連接池是C3P0,Proxool,以及DBCP。在配置連接池時(shí)需要注意的有三點(diǎn):
一、Apche的DBCP在Hibernate2中受支持,但在Hibernate3中已經(jīng)不再推薦使用,官方的解釋是這個(gè)連接池存在缺陷。如果你因?yàn)槟撤N原因需要在Hibernate3中使用DBCP,考試,大建議采用JNDI方式。
二、默認(rèn)情況下(即沒有配置連接池的情況下),Hibernate會(huì)采用內(nèi)建的連接池。但這個(gè)連接池性能不佳,且存在諸多BUG,因此官方也只是建議僅在開發(fā)環(huán)境下使用。
三、Hibernate2和Hibernate3的命名空間有所變化。例如,配置C3P0時(shí)的provider_class有Hibernate2環(huán)境下使用net.sf.hibernate.connection.C3P0ConnectionProvider,在Hibernate3環(huán)境下使用org.hibernate.connection.C3P0ConnectionProvider。
下面是Hibernate環(huán)境下幾種常見的連接池配置,都是以連接MySQl為例。
org.gjt.mm.mysql.Driver
jdbc:mysql://localhost:3306/struts?useUnicode=true
& characterEncoding=GBK
root
8888
上面的一段配置,在c3p0和dbcp中,都是必需的,因?yàn)閔ibernate會(huì)根據(jù)上述的配置來生成connections,再交給c3p0或dbcp管理。但是proxool則不能,可以讓proxool自身來生成連接,這在下面再講。
從網(wǎng)上google了一下,發(fā)現(xiàn)大致有三種可以實(shí)施的解決方案:
1、使用hibernate自帶的連接池;
2、使用c3po包的連接池功能;
3、使用dbcp包的連接池功能;
4、使用Proxool包的連接池功能;
第一種方案,Hibernate默認(rèn)連接池,就是在myeclipse產(chǎn)生的hibernate.cfg.xml中添加一個(gè)屬性:
20
第二種方案是:C3P0
只需在hibernate.cfg.xml中加入
2
10
1800
4
1
36000
2
10
1200
30
2
org.hibernate.connection.C3P0ConnectionProvider
還有在classespath中加入c3p0-0.8.4.5.jar
第三種方案是:dbcp
在hibernate.cfg.xml中加入
100
1
60000
10
100
1
60000
10
還有在classespath中加入commons-pool-1.2.jar 和commons-dbcp-1.2.1.jar.
第四種方案是:Proxool
建立一個(gè)Proxool.xml文件:
mysql
jdbc:mysql://localhost:3306/jackdemo
com.mysql.jdbc.Driver
60000
100
2
100
10
現(xiàn)在來看下配置的意思:
配置連接池的別名;
和寫JDBC連接數(shù)據(jù)庫時(shí)的URL一樣。
和寫JDBC連接數(shù)據(jù)庫時(shí)的Driver一樣。
就是連接數(shù)據(jù)庫時(shí)的用戶名和密碼。
proxool自動(dòng)偵察各個(gè)連接狀態(tài)的時(shí)間間隔(毫秒),偵察到空閑的連接就馬上回收,超時(shí)的銷毀
最少保持的空閑連接數(shù)
連接數(shù)。
最小連接數(shù)。
以下是在Hibernate配置文件中對(duì)連接池的配置:
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
org.hibernate.connection.ProxoolConnectionProvider
mysql
config/proxool/proxool.xml
true
五.JNDI連接池。數(shù)據(jù)源已經(jīng)由應(yīng)用服務(wù)配置好(如Web服務(wù)器),Hibernate需要做的只是通過JNDI名查找到此數(shù)據(jù)源。應(yīng)用服務(wù)器將連接池對(duì)外顯示為JNDI綁定數(shù)據(jù)源,它是javax.jdbc.Datasource類的一個(gè)實(shí)例。只要配置一個(gè)Hibernate文件,如:
hibernate.connection.datasource = java:/comp/env/jdbc/portal //JNDI名
hibernate.transaction.factory_class = org.hibernate.transaction.JTATransactionFactory
hibernate.transaction.manager_loopup_class = org.hibernate.transaction.JBossTransactionManagerLookup
hibernate.dialect = org.hibernate.dialect.MySQLDialect。
一、Apche的DBCP在Hibernate2中受支持,但在Hibernate3中已經(jīng)不再推薦使用,官方的解釋是這個(gè)連接池存在缺陷。如果你因?yàn)槟撤N原因需要在Hibernate3中使用DBCP,考試,大建議采用JNDI方式。
二、默認(rèn)情況下(即沒有配置連接池的情況下),Hibernate會(huì)采用內(nèi)建的連接池。但這個(gè)連接池性能不佳,且存在諸多BUG,因此官方也只是建議僅在開發(fā)環(huán)境下使用。
三、Hibernate2和Hibernate3的命名空間有所變化。例如,配置C3P0時(shí)的provider_class有Hibernate2環(huán)境下使用net.sf.hibernate.connection.C3P0ConnectionProvider,在Hibernate3環(huán)境下使用org.hibernate.connection.C3P0ConnectionProvider。
下面是Hibernate環(huán)境下幾種常見的連接池配置,都是以連接MySQl為例。
& characterEncoding=GBK
上面的一段配置,在c3p0和dbcp中,都是必需的,因?yàn)閔ibernate會(huì)根據(jù)上述的配置來生成connections,再交給c3p0或dbcp管理。但是proxool則不能,可以讓proxool自身來生成連接,這在下面再講。
從網(wǎng)上google了一下,發(fā)現(xiàn)大致有三種可以實(shí)施的解決方案:
1、使用hibernate自帶的連接池;
2、使用c3po包的連接池功能;
3、使用dbcp包的連接池功能;
4、使用Proxool包的連接池功能;
第一種方案,Hibernate默認(rèn)連接池,就是在myeclipse產(chǎn)生的hibernate.cfg.xml中添加一個(gè)屬性:
第二種方案是:C3P0
只需在hibernate.cfg.xml中加入
還有在classespath中加入c3p0-0.8.4.5.jar
第三種方案是:dbcp
在hibernate.cfg.xml中加入
還有在classespath中加入commons-pool-1.2.jar 和commons-dbcp-1.2.1.jar.
第四種方案是:Proxool
建立一個(gè)Proxool.xml文件:
mysql
jdbc:mysql://localhost:3306/jackdemo
com.mysql.jdbc.Driver
60000
100
2
100
10
現(xiàn)在來看下配置的意思:
配置連接池的別名;
proxool自動(dòng)偵察各個(gè)連接狀態(tài)的時(shí)間間隔(毫秒),偵察到空閑的連接就馬上回收,超時(shí)的銷毀
以下是在Hibernate配置文件中對(duì)連接池的配置:
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
org.hibernate.connection.ProxoolConnectionProvider
mysql
config/proxool/proxool.xml
五.JNDI連接池。數(shù)據(jù)源已經(jīng)由應(yīng)用服務(wù)配置好(如Web服務(wù)器),Hibernate需要做的只是通過JNDI名查找到此數(shù)據(jù)源。應(yīng)用服務(wù)器將連接池對(duì)外顯示為JNDI綁定數(shù)據(jù)源,它是javax.jdbc.Datasource類的一個(gè)實(shí)例。只要配置一個(gè)Hibernate文件,如:
hibernate.connection.datasource = java:/comp/env/jdbc/portal //JNDI名
hibernate.transaction.factory_class = org.hibernate.transaction.JTATransactionFactory
hibernate.transaction.manager_loopup_class = org.hibernate.transaction.JBossTransactionManagerLookup
hibernate.dialect = org.hibernate.dialect.MySQLDialect。