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

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

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

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

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

    出現(xià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.環(huán)境:

    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條件取出來,清空兩者來執(zhí)行Count操作    
        Projection projection = impl.getProjection();    
        
    //獲取總記錄數(shù)    
        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);    
        
    //取得結(jié)果    
        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次,服務器就沒響應了,最后出現(xiàn)上面的錯誤的了。

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

    前天解決了。

    問題解決,問題的原因是數(shù)據(jù)庫連接耗盡,我用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釋放后就沒事了,調(diào)用HiberanteDaoSupport的releaseSession(session);方法后即可解決。


    現(xiàn)在正確的代碼:


    public Page listByPage(Class entityClass, int pageNo, int pageSize, List criterions, List orders) {    
        Session session 
    = getSession();    
        
    //創(chuàng)建criteria    
        Criteria criteria = session.createCriteria(entityClass);    
        
    //為criteria添加criterions    
        createCriteria(entityClass, criteria, criterions);    
        CriteriaImpl impl 
    = (CriteriaImpl) criteria;    
       
        
    // 先把Projection和OrderBy條件取出來,清空兩者來執(zhí)行Count操作    
        Projection projection = impl.getProjection();    
        
    //獲取總記錄數(shù)    
        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);    
        
    //取得結(jié)果    
        List list = criteria.setFirstResult(startIndex).setMaxResults(pageSize).list();    
        
    //釋放hiberante資源,一定要釋放,要不然就數(shù)據(jù)庫連接耗盡.    
        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 流浪汗 閱讀(6114) 評論(4)  編輯  收藏 所屬分類: JAVA/J2EE

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

    使用UFO做Web Server的好處是網(wǎng)站能做得很穩(wěn)定,永遠也不會自己down掉;UFO在托管機房丟包率很高、遭受Hacker攻擊、互聯(lián)網(wǎng) 骨干網(wǎng)被黑等惡劣的環(huán)境條件下仍然能很好地運行;UFO在對付Hacker方面(防Hacker弄down和Hacker抓取不該訪問的資源)也有足 夠措施。
    另外,UFO幾乎不會進行垃圾回收,消耗CPU很少,在普通的PC Server上用UFO運行網(wǎng)站,平時CPU占用率<0.1%,最多時也不會超 過5%。您知道,JVM的垃圾回收會導致大量的運算,消耗很多CPU,從而導致Server的負載能力和響應速度下降。UFO在對象管理方面采 用了很好的機制和算法,做得很出色。用UFO運行網(wǎng)站,可以一直保證高負載能力,快速的響應速度和低CPU消耗。
      回復  更多評論
      
    # re: weblogic 8.1.4服務器掛起,出現(xiàn)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: ... 產(chǎn)生此錯誤是由于 WebLogic Server 超過了其“阻塞線程最長時間:”的默認值:600 秒。

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

      回復  更多評論
      
    主站蜘蛛池模板: 日日狠狠久久偷偷色综合免费| 99视频在线免费| 久久精品视频亚洲| 成人免费无码大片a毛片| 一区二区视频免费观看| 一级成人毛片免费观看| 亚洲av丰满熟妇在线播放| 国产桃色在线成免费视频| 免费观看又污又黄在线观看| 久久久综合亚洲色一区二区三区 | 羞羞漫画页面免费入口欢迎你| 久久亚洲国产精品五月天婷| 免费观看美女用震蛋喷水的视频 | 国产香蕉免费精品视频| 免费国产黄网站在线看| 亚洲春色在线观看| 亚洲精品亚洲人成在线观看下载 | 黄网站免费在线观看| 亚洲美国产亚洲AV| 亚洲AV成人片色在线观看高潮 | 中文字幕亚洲电影| 思思99re66在线精品免费观看| 手机看片国产免费永久| 亚洲国产欧美日韩精品一区二区三区 | 91av免费观看| 久久久精品国产亚洲成人满18免费网站 | 99re热免费精品视频观看| 成人性生交大片免费看好| 亚洲av无码日韩av无码网站冲| 久久夜色精品国产噜噜亚洲AV| 亚洲裸男gv网站| 日韩成人免费视频播放| 69av免费视频| 三年片在线观看免费大全电影| 人体大胆做受免费视频| 日韩成人精品日本亚洲| 在线综合亚洲中文精品| 亚洲码一区二区三区| 久久精品国产亚洲夜色AV网站| 亚洲伊人久久综合影院| 免费成人黄色大片|