vickzhu

            BlogJava :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
            151 隨筆 :: 0 文章 :: 34 評論 :: 0 Trackbacks
          Hibernate支持第三方的連接池,官方推薦的連接池是C3P0,Proxool,以及DBCP。在配置連接池時需要注意的有三點:
            一、Apche的DBCP在Hibernate2中受支持,但在Hibernate3中已經(jīng)不再推薦使用,官方的解釋是這個連接池存在缺陷。如果你因為某種原因需要在Hibernate3中使用DBCP,建議采用JNDI方式。
            二、默認情況下(即沒有配置連接池的情況下),Hibernate會采用內(nèi)建的連接池。但這個連接池性能不佳,且存在諸多BUG,因此官方也只是建議僅在開發(fā)環(huán)境下使用。
            三、Hibernate2和Hibernate3的命名空間有所變化。例如,配置C3P0時的provider_class有Hibernate2環(huán)境下使用net.sf.hibernate.connection.C3P0ConnectionProvider,在Hibernate3環(huán)境下使用org.hibernate.connection.C3P0ConnectionProvider。
            下面是Hibernate環(huán)境下幾種常見的連接池配置,都是以連接MySQl為例。
            <!-- JDBC驅(qū)動程序 -->
            <property name="connection.driver_class">org.gjt.mm.mysql.Driver</property>
            <property name="connection.url">jdbc:mysql://localhost:3306/struts?useUnicode=true
            & characterEncoding=GBK</property>
            <!-- 數(shù)據(jù)庫用戶名 -->
            <property name="connection.username">root</property>
            <!-- 數(shù)據(jù)庫密碼 -->
            <property name="connection.password">8888</property>
            上面的一段配置,在c3p0和dbcp中,都是必需的,因為hibernate會根據(jù)上述的配置來生成connections,再交給c3p0或dbcp管理。但是proxool則不能,可以讓proxool自身來生成連接,這在下面再講。
            從網(wǎng)上google了一下,發(fā)現(xiàn)大致有三種可以實施的解決方案:
            1、使用hibernate自帶的連接池;
            2、使用c3po包的連接池功能;
            3、使用dbcp包的連接池功能;
            4、使用Proxool包的連接池功能;
                  5、使用JNDI連接池
            第一種方案,Hibernate默認連接池,就是在myeclipse產(chǎn)生的hibernate.cfg.xml中添加一個屬性:
            <property name="connection.pool_size">20</property>
            第二種方案是:C3P0
            只需在hibernate.cfg.xml中加入
            <property name="c3p0.min_size">2</property>
            <property name="c3p0.max_size">10</property>
            <property name="c3p0.timeout">1800</property>
            <property name="c3p0.acquireRetryAttempts">4</property>
            <property name="c3p0.acquireIncrement">1</property>
            <property name="c3p0.idleConnectionTestPeriod">36000</property>
            <property name="c3p0.initialPoolSize">2</property>
            <property name="c3p0.maxPoolSize">10</property>
            <property name="c3p0.maxIdleTime">1200</property>
            <property name="c3p0.maxStatements">30</property>
            <property name="c3p0.minPoolSize">2</property>
            <property name="connection.provider_class">org.hibernate.connection.C3P0ConnectionProvider</property>
            還有在classespath中加入c3p0-0.8.4.5.jar
            第三種方案是:dbcp
            在hibernate.cfg.xml中加入
            <property name="dbcp.maxActive">100</property>
            <property name="dbcp.whenExhaustedAction">1</property>
            <property name="dbcp.maxWait">60000</property>
            <property name="dbcp.maxIdle">10</property>
            <property name="dbcp.ps.maxActive">100</property>
            <property name="dbcp.ps.whenExhaustedAction">1</property>
            <property name="dbcp.ps.maxWait">60000</property>
            <property name="dbcp.ps.maxIdle">10</property>
            還有在classespath中加入commons-pool-1.2.jar 和commons-dbcp-1.2.1.jar.
            第四種方案是:Proxool
            建立一個Proxool.xml文件:
            <?xml version="1.0" encoding="UTF-8"?>
            <!-- the proxool configuration can be embedded within your own application’s.
            Anything outside the "proxool" tag is ignored. -->
            <something-else-entirely>
            <proxool>
            <alias>
            mysql
            </alias>
            <driver-url>
            jdbc:mysql://localhost:3306/jackdemo
            </driver-url>
            <driver-class>
            com.mysql.jdbc.Driver
            </driver-class>
            <driver-properties>
            <property name="user" value="root" />
            <property name="password" value="jack" />
            </driver-properties>
            <house-keeping-sleep-time>
            60000
            </house-keeping-sleep-time>
            <proxool.simultaneous-build-throttle>
            100
            </proxool.simultaneous-build-throttle>
            <prototype-count>
            2
            </prototype-count>
            <maximum-connection-count>
            100
            </maximum-connection-count>
            <minimum-connection-count>
            10
            </minimum-connection-count>
            </proxool>
            </something-else-entirely>
            現(xiàn)在來看下配置的意思:
            <alias>配置連接池的別名;
            <driver-url>和寫JDBC連接數(shù)據(jù)庫時的URL一樣。
            <driver-class>和寫JDBC連接數(shù)據(jù)庫時的Driver一樣。
            <driver-properies>就是連接數(shù)據(jù)庫時的用戶名和密碼。
            <house-keeping-sleep-time>proxool自動偵察各個連接狀態(tài)的時間間隔(毫秒),偵察到空閑的連接就馬上回收,超時的銷毀
            <prototype-count>最少保持的空閑連接數(shù)
            <maximum-connection-count>最大連接數(shù)。
            <minimum-connection-count>最小連接數(shù)。
            以下是在Hibernate配置文件中對連接池的配置:
            <?xml version=’1.0’ encoding=’UTF-8’?>
            <!DOCTYPE hibernate-configuration PUBLIC
            "-//Hibernate/Hibernate Configuration DTD 3.0//EN"
            "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
            <hibernate-configuration>
            <session-factory>
            <!-- proxool連接池加載的類-->
            <property name="hibernate.connection.provider_class">
            org.hibernate.connection.ProxoolConnectionProvider
            </property>
            <!--連接池的別名,即配置連接池時起的別名-->
            <property name="hibernate.proxool.pool_alias">
            mysql
            </property>
            <!--連接池文件的地址-->
            <property name="hibernate.proxool.xml">
            config/proxool/proxool.xml
            </property>
            <!--是否將運行期生成的SQL輸出到日志以供調(diào)試-->
            <property name="show_sql">true</property>
            <mapping resource="com/jack/ssh/demo/bo/City.hbm.xml" />
            <mapping resource="com/jack/ssh/demo/bo/Province.hbm.xml" />
            </session-factory>
            </hibernate-configuration>
            第五種方案是:JNDI連接池。數(shù)據(jù)源已經(jīng)由應用服務配置好(如Web服務器),Hibernate需要做的只是通過JNDI名查找到此數(shù)據(jù)源。應用服務器將連接池對外顯示為JNDI綁定數(shù)據(jù)源,它是javax.jdbc.Datasource類的一個實例。只要配置一個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。
          posted on 2009-03-10 09:23 筱 筱 閱讀(485) 評論(0)  編輯  收藏

          只有注冊用戶登錄后才能發(fā)表評論。


          網(wǎng)站導航:
           
          主站蜘蛛池模板: 县级市| 类乌齐县| 大田县| 遂宁市| 昌黎县| 庆城县| 永和县| 鱼台县| 彭州市| 志丹县| 科技| 女性| 保定市| 玉龙| 嘉定区| 宝山区| 抚顺市| 平湖市| 饶阳县| 额敏县| 湾仔区| 班戈县| 阜新市| 天气| 温泉县| 扶风县| 安福县| 纳雍县| 关岭| 光泽县| 晴隆县| 松桃| 台州市| 光山县| 都兰县| 台南县| 开原市| 左云县| 河曲县| 巨鹿县| 油尖旺区|