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

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

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

    vickzhu

      BlogJava :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
      151 隨筆 :: 0 文章 :: 34 評論 :: 0 Trackbacks
    Hibernate支持第三方的連接池,官方推薦的連接池是C3P0,Proxool,以及DBCP。在配置連接池時需要注意的有三點:
      一、Apche的DBCP在Hibernate2中受支持,但在Hibernate3中已經不再推薦使用,官方的解釋是這個連接池存在缺陷。如果你因為某種原因需要在Hibernate3中使用DBCP,建議采用JNDI方式。
      二、默認情況下(即沒有配置連接池的情況下),Hibernate會采用內建的連接池。但這個連接池性能不佳,且存在諸多BUG,因此官方也只是建議僅在開發環境下使用。
      三、Hibernate2和Hibernate3的命名空間有所變化。例如,配置C3P0時的provider_class有Hibernate2環境下使用net.sf.hibernate.connection.C3P0ConnectionProvider,在Hibernate3環境下使用org.hibernate.connection.C3P0ConnectionProvider。
      下面是Hibernate環境下幾種常見的連接池配置,都是以連接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>
      <!-- 數據庫用戶名 -->
      <property name="connection.username">root</property>
      <!-- 數據庫密碼 -->
      <property name="connection.password">8888</property>
      上面的一段配置,在c3p0和dbcp中,都是必需的,因為hibernate會根據上述的配置來生成connections,再交給c3p0或dbcp管理。但是proxool則不能,可以讓proxool自身來生成連接,這在下面再講。
      從網上google了一下,發現大致有三種可以實施的解決方案:
      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>
      現在來看下配置的意思:
      <alias>配置連接池的別名;
      <driver-url>和寫JDBC連接數據庫時的URL一樣。
      <driver-class>和寫JDBC連接數據庫時的Driver一樣。
      <driver-properies>就是連接數據庫時的用戶名和密碼。
      <house-keeping-sleep-time>proxool自動偵察各個連接狀態的時間間隔(毫秒),偵察到空閑的連接就馬上回收,超時的銷毀
      <prototype-count>最少保持的空閑連接數
      <maximum-connection-count>最大連接數。
      <minimum-connection-count>最小連接數。
      以下是在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連接池。數據源已經由應用服務配置好(如Web服務器),Hibernate需要做的只是通過JNDI名查找到此數據源。應用服務器將連接池對外顯示為JNDI綁定數據源,它是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)  編輯  收藏

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


    網站導航:
     
    主站蜘蛛池模板: 国产成人免费午夜在线观看| 国产乱子伦片免费观看中字| 中文字幕免费在线播放| 免费人成在线观看网站| 国产乱辈通伦影片在线播放亚洲| 精品在线免费视频| 香蕉视频在线观看免费国产婷婷 | 亚洲天堂免费在线视频| 风间由美在线亚洲一区| 亚洲A∨午夜成人片精品网站| 全黄A免费一级毛片| 久久久久噜噜噜亚洲熟女综合| 日韩大片在线永久免费观看网站| 亚洲av日韩av欧v在线天堂| 人妻仑乱A级毛片免费看| 亚洲熟女少妇一区二区| 国产男女猛烈无遮挡免费视频 | 亚洲色偷拍区另类无码专区| 亚洲综合国产精品第一页| 亚洲高清在线观看| 最近免费中文字幕mv在线电影| 亚洲人妖女同在线播放| 午夜国产大片免费观看| 国产精品永久免费视频| 99亚洲精品高清一二区| 国内精品免费视频自在线| 人成午夜免费大片在线观看| 亚洲an天堂an在线观看| 性xxxx视频播放免费| selaoban在线视频免费精品| 青青草原精品国产亚洲av| 成人免费a级毛片无码网站入口 | 五月婷婷在线免费观看| 国产精品亚洲专区无码牛牛| 亚洲国产精品乱码一区二区| 永久免费AV无码国产网站| 亚洲免费视频一区二区三区| 亚洲精品综合久久中文字幕| 免费一区二区视频| 1000部啪啪毛片免费看| 最新亚洲人成无码网www电影|