隨筆-153  評論-235  文章-19  trackbacks-0

          前幾天用spring+hibernate+struts寫了個增/刪/改/查的例子。調試期間問題就來了,當查詢結果翻頁好幾次就沒N久沒有響應了。最后控制報錯。網上查了,它說數據庫連接(池)問題。

          出現錯誤如下:

          <2007-9-30 下午120303 CST> <Error> <WebLogicServer> <BEA-000337> <ExecuteThread: '13' for queue: 'weblogic.kernel.Default' has been busy for "901" seconds working on the request "Http Request: /admin/school.do", which is more than the configured time (StuckThreadMaxTime) of "600" seconds.>

          先說下我配置

          1.環境:

          spring 2.0.6,hibernate 3.2.3,struts 1.2.9,oracle 10.2,weblogic 8.1.4

          jdbc是ojdbc14.jar

          2.連接池用DBCP

          <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">   
              
          <property name="driverClassName" value="${jdbc.driverClassName}"/>   
              
          <property name="url" value="${jdbc.url}"/>   
              
          <property name="username" value="${jdbc.username}"/>   
              
          <property name="password" value="${jdbc.password}"/>   
          bean>   

          3.分頁方法(參考springside的),此類繼承HibernateDaoSupport
          public Page listByPage(Class entityClass, int pageNo, int pageSize, List criterions, List orders) {    
              Criteria criteria 
          = createCriteria(entityClass, criterions);    
              CriteriaImpl impl 
          = (CriteriaImpl) criteria;    
             
              
          // 先把Projection和OrderBy條件取出來,清空兩者來執行Count操作    
              Projection projection = impl.getProjection();    
              
          //獲取總記錄數    
              int totalCount = ((Integer) criteria.setProjection(Projections.rowCount()).uniqueResult()).intValue();    
             
                  
              
          if(totalCount < 1) {    
                  
          return new Page();    
              }    
                  
              
          //加排序    
              if(orders != null) {    
                  
          for(int i=0; i 
                      criteria.addOrder((Order) orders.get(i));    
                  }    
              }    
              
          //原來的投影    
              criteria.setProjection(projection);    
              
          int startIndex = Page.getStartOfPage(pageNo, pageSize);    
              
          //取得結果    
              List list = criteria.setFirstResult(startIndex).setMaxResults(pageSize).list();    
                  
              
          return new Page(startIndex, totalCount, pageSize, list);    
          }    
             
          public Criteria createCriteria(Class entityClass, List criterions) {    
              Criteria criteria 
          = getSession().createCriteria(entityClass);    
              
          if(criterions != null) {    
                  
          for(int i=0; i 
                      criteria.add((Criterion) criterions.get(i));    
                  }    
              }    
                  
              
          return criteria;    
          }   

          另外,沒有用OpenSessionInViewFilter,struts與spring的整合:DelegatingRequestProcessor、action path與bean name同名。

           

          翻頁不過10次,服務器就沒響應了,最后出現上面的錯誤的了。

          剛用weblogic,也剛用ssh套餐。郁悶。

          前天解決了。

          問題解決,問題的原因是數據庫連接耗盡,我用HiberanteDaoSupport的getSession()方法取得Session后沒有釋放Session。

          出問題的代碼處(紅色部分):

          public Criteria createCriteria(Class entityClass, List criterions) {        
              Criteria criteria 
          = getSession().createCriteria(entityClass);        
              
          if(criterions != null) {        
                  
          for(int i=0; i     
                      criteria.add((Criterion) criterions.get(i));        
                  }        
              }        
                      
              
          return criteria;        
          }   

          用完Session釋放后就沒事了,調用HiberanteDaoSupport的releaseSession(session);方法后即可解決。


          現在正確的代碼:


          public Page listByPage(Class entityClass, int pageNo, int pageSize, List criterions, List orders) {    
              Session session 
          = getSession();    
              
          //創建criteria    
              Criteria criteria = session.createCriteria(entityClass);    
              
          //為criteria添加criterions    
              createCriteria(entityClass, criteria, criterions);    
              CriteriaImpl impl 
          = (CriteriaImpl) criteria;    
             
              
          // 先把Projection和OrderBy條件取出來,清空兩者來執行Count操作    
              Projection projection = impl.getProjection();    
              
          //獲取總記錄數    
              int totalCount = ((Integer) criteria.setProjection(Projections.rowCount()).uniqueResult()).intValue();    
             
                  
              
          if(totalCount < 1) {    
                  
          return new Page();    
              }    
                  
              
          //加排序    
              if(orders != null) {    
                  
          for(int i=0; i 
                      criteria.addOrder((Order) orders.get(i));    
                  }    
              }    
              
          //原來的投影    
              criteria.setProjection(projection);    
              
          int startIndex = Page.getStartOfPage(pageNo, pageSize);    
              
          //取得結果    
              List list = criteria.setFirstResult(startIndex).setMaxResults(pageSize).list();    
              
          //釋放hiberante資源,一定要釋放,要不然就數據庫連接耗盡.    
              releaseSession(session);    
              
          return new Page(startIndex, totalCount, pageSize, list);    
          }    
             
          public Criteria createCriteria(Class entityClass, Criteria criteria, List criterions) {    
              
          if(criterions != null) {    
                  
          for(int i=0; i 
                      criteria.add((Criterion) criterions.get(i));    
                  }    
              }    
                  
              
          return criteria;    
          }   


          ^_^
          posted on 2007-10-06 21:10 流浪汗 閱讀(6124) 評論(4)  編輯  收藏 所屬分類: JAVA/J2EE

          評論:
          # re: weblogic 8.1.4服務器掛起,出現StuckThreadMaxTime錯誤 2009-03-16 13:47 | xukai_286
          既然用了ssh,為何不用spring的申明式事務控制,而把這些事務控制加入到代碼中,看著也心煩。  回復  更多評論
            
          # re: weblogic 8.1.4服務器掛起,出現StuckThreadMaxTime錯誤 2009-04-17 09:36 | zhang3
          謝謝,正需要呢  回復  更多評論
            
          # re: weblogic 8.1.4服務器掛起,出現StuckThreadMaxTime錯誤 2009-05-13 15:33 | 365
          用UFO就不會出現這類現象,www.gm365.com上發布的:
          ∵ 最新公告
          (2009年5月11日)
            [UFO下載]:UFO 1.10版發布(點此下載)。1.10版糾正1.00版中對新建的Context需要手工創建WORK目錄的問題和https狀態下的幾個Bug。 1.00版提供全新的examples demo,對中文亂碼問題的解決給出足夠的示例,可以配置多個數據庫連接池,動態檢查裝載servlet,提供詳細的Howto文檔(閱讀此Howto文檔)。UFO自0.975版以來已很穩定地運行(作為gm365網站的web server),不會出現一個字節的內存泄漏和一個線程的不能回收。 UFO:一個支持Jsp、Servlet、靜態網頁、虛擬主機、數據庫連接池、http、https、無線互聯網mimeType標準、認證和Tag庫的Web Server。

          使用UFO做Web Server的好處是網站能做得很穩定,永遠也不會自己down掉;UFO在托管機房丟包率很高、遭受Hacker攻擊、互聯網 骨干網被黑等惡劣的環境條件下仍然能很好地運行;UFO在對付Hacker方面(防Hacker弄down和Hacker抓取不該訪問的資源)也有足 夠措施。
          另外,UFO幾乎不會進行垃圾回收,消耗CPU很少,在普通的PC Server上用UFO運行網站,平時CPU占用率<0.1%,最多時也不會超 過5%。您知道,JVM的垃圾回收會導致大量的運算,消耗很多CPU,從而導致Server的負載能力和響應速度下降。UFO在對象管理方面采 用了很好的機制和算法,做得很出色。用UFO運行網站,可以一直保證高負載能力,快速的響應速度和低CPU消耗。
            回復  更多評論
            
          # re: weblogic 8.1.4服務器掛起,出現StuckThreadMaxTime錯誤 2010-12-11 14:02 | 天藍色
          @365
          配置期間超過了 WebLogic Server StuckThreadMaxTime 值
          如果正在使用配置程序配置 WebLogic Server 9.2 MP2 或 10,并且完成配置花費的時間超過 600 秒,則會將以下錯誤返回到終端、WebLogic Server 域和服務器日志:

          <Error> <WebLogicServer> <BEA-000337> <[STUCK] Exe
          cuteThread: '5' for queue: 'weblogic.kernel.Default (self-tuning)' has been busy
          for "681" seconds working on the request "Http Request: /opensso/setup/setSetup
          Progress", which is more than the configured time (StuckThreadMaxTime) of "600"
          seconds. Stack trace: ... 產生此錯誤是由于 WebLogic Server 超過了其“阻塞線程最長時間:”的默認值:600 秒。

          解決方法。如果配置程序沒有響應,則重新啟動。同時,考慮將 WebLogic Server 的“阻塞線程最長時間”的值從默認的 600 秒更改為更大的值,例如 1200 秒。使用 WebLogic 控制臺更改該值(base_domain >“環境”>“服務器”>“管理服務器”>“配置/調節”)。

            回復  更多評論
            

           
          <2007年10月>
          30123456
          78910111213
          14151617181920
          21222324252627
          28293031123
          45678910

          留言簿(14)

          隨筆分類

          隨筆檔案

          文章分類

          文章檔案

          新聞分類

          新聞檔案

          收藏夾

          友情鏈接

          同學鏈接

          學習鏈接

          最新隨筆

          搜索

          •  

          積分與排名

          • 積分 - 560777
          • 排名 - 86

          最新評論

          閱讀排行榜

          評論排行榜

          主站蜘蛛池模板: 永新县| 合川市| 嫩江县| 田林县| 剑阁县| 桑日县| 普洱| 利津县| 怀集县| 固始县| 永福县| 金川县| 保德县| 阳城县| 台北县| 栖霞市| 昌乐县| 太保市| 银川市| 芒康县| 南宁市| 江都市| 吕梁市| 涪陵区| 五河县| 栾城县| 都江堰市| 洞头县| 天峻县| 瑞昌市| 安丘市| 兴仁县| 长子县| 闽清县| 林周县| 四子王旗| 淮南市| 寿光市| 鱼台县| 突泉县| 河间市|