<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    vickzhu

      BlogJava :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
      151 隨筆 :: 0 文章 :: 34 評論 :: 0 Trackbacks
    Hibernate支持第三方的連接池,官方推薦的連接池是C3P0,Proxool,以及DBCP。在配置連接池時需要注意的有三點:
      一、Apche的DBCP在Hibernate2中受支持,但在Hibernate3中已經不再推薦使用,官方的解釋是這個連接池存在缺陷。如果你因為某種原因需要在Hibernate3中使用DBCP,建議采用JNDI方式。
      二、默認情況下(即沒有配置連接池的情況下),Hibernate會采用內建的連接池。但這個連接池性能不佳,且存在諸多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驅動程序 -->
      <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自身來生成連接,這在下面再講。
      從網上google了一下,發(fā)現(xiàn)大致有三種可以實施的解決方案:
      1、使用hibernate自帶的連接池;
      2、使用c3po包的連接池功能;
      3、使用dbcp包的連接池功能;
      4、使用Proxool包的連接池功能;
            5、使用JNDI連接池
      第一種方案,Hibernate默認連接池,就是在myeclipse產生的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輸出到日志以供調試-->
      <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ù)源已經由應用服務配置好(如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 筱 筱 閱讀(481) 評論(0)  編輯  收藏

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


    網站導航:
     
    主站蜘蛛池模板: 在线综合亚洲欧洲综合网站| 久久亚洲私人国产精品| 亚洲欧好州第一的日产suv| 国产精品永久免费10000| 亚洲国产精品张柏芝在线观看| 57pao一国产成视频永久免费| 亚洲欧洲校园自拍都市| 24小时免费直播在线观看| 亚洲av极品无码专区在线观看| 国产一卡2卡3卡4卡2021免费观看 国产一卡2卡3卡4卡无卡免费视频 | 老司机亚洲精品影院| 最近2022中文字幕免费视频 | 亚洲一区二区三区国产精品无码| 无码国产精品一区二区免费I6| 亚洲欧洲无码一区二区三区| 暖暖在线日本免费中文| 午夜肉伦伦影院久久精品免费看国产一区二区三区 | 亚洲精品亚洲人成在线| 亚洲欧洲精品成人久久曰影片| 国产乱子伦精品免费视频| 亚洲av无码av制服另类专区| 222www免费视频| 亚洲高清毛片一区二区| 亚洲欧洲精品成人久久曰影片| 久别的草原电视剧免费观看| 亚洲成年人电影网站| 国产免费AV片无码永久免费| 成在线人视频免费视频| 亚洲尹人九九大色香蕉网站| 成年女人毛片免费视频| av电影在线免费看| 亚洲系列中文字幕| 深夜国产福利99亚洲视频| 亚洲免费在线视频| 亚洲精品无码av片| 亚洲成亚洲乱码一二三四区软件| 成人免费在线视频| 3344在线看片免费| 亚洲精品成a人在线观看夫| 亚洲综合色婷婷七月丁香| 免费可以在线看A∨网站|