posts - 3,  comments - 14,  trackbacks - 0
          hibernate默認連接池有一個問題,不會自動檢測數據庫連接是否斷開,MYSQL數據庫一段時間(大約8小時)沒有訪問就會斷開連接,連接池里的連接卻還是存在,下次訪問hibernate會繼續使用這個連接,導致數據庫連接異常。由于該問題需要在服務器長時間運行時才會出現,所以在平時測試很難發現。

          解決方法:
          1.在連接參數中使用autoReconnect以后,第一次執行失敗后會自動重新連接。
          2.通過把服務器上Mysql的"wait_timeout"屬性設置的高點。
          3.不使用Hibernate內置的連接池,改用C3P0連接池,這個連接池會自動處理數據庫連接被關閉的情況。要使用C3P0很簡單,先從Hibernate里把c3p0-0.8.3.jar復制到項目的lib目錄中,再在hibernate.properties里去掉hibernate.c3p0開頭的那些屬性的注釋(使用缺省值或自己需要的數值),這樣 Hibernate就會自動使用C3P0代替內置的連接池了。c3p0為open source的JDBC連接池,隨hibernate一起發布。c3p0連接池的配置非常簡單,只需要在hibernate.cfg.xml里增加:
                  <!-- configuration pool -->
                  <property name="c3p0.acquire_increment">1</property>
                  <property name="c3p0.idle_test_period">100</property> <!-- seconds -->
                  <property name="c3p0.max_size">5</property>
                  <property name="c3p0.max_statements">0</property>
                  <property name="c3p0.min_size">2</property>
                  <property name="c3p0.timeout">90</property> <!-- seconds -->
          另外,還需要在CLASS_PATH里加上c3p0-x.x.x.jar文件(x.x.x為版本號),c3p0-x.x.x.jar文件隨hibernate一起發布,你可以在其lib目錄下找到該文件。
          配置好之后,hibernate便會自動使用c3p0的連接池:C3P0ConnectionProvider


          www.jhost.cn免費JSP、PHP主機空間,提供MYSQL數據庫,支持常用J2EE框架,FTP文件管理。

          posted on 2009-06-13 05:57 jhost 閱讀(2158) 評論(2)  編輯  收藏

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


          網站導航:
           
          主站蜘蛛池模板: 上高县| 元朗区| 洛隆县| 怀柔区| 兴仁县| 徐水县| 峡江县| 东莞市| 什邡市| 南漳县| 开平市| 兴山县| 益阳市| 丰顺县| 临清市| 白玉县| 宝丰县| 北票市| 清涧县| 济源市| 依安县| 綦江县| 会昌县| 麟游县| 栾川县| 正宁县| 瑞安市| 西充县| 通辽市| 汕头市| 绥德县| 启东市| 内黄县| 云浮市| 兰州市| 游戏| 塔城市| 油尖旺区| 抚顺县| 科技| 舟曲县|