JAVA技巧:Hibernate配置數(shù)據(jù)連接池

字號(hào):

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。