`
chenlb
  • 浏览: 695653 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

weblogic 8.1.4服务器挂起,出现StuckThreadMaxTime错误

阅读更多

前几天用spring+hibernate+struts写了个增/删/改/查的例子。调试期间问题就来了,当查询结果翻页好几次就没N久没有响应了。最后控制报错。网上查了,它说数据库连接(池)问题。

出现错误如下:

<<st1:chsdate w:st="on" isrocdate="False" islunardate="False" day="30" month="9" year="2007">2007-9-30</st1:chsdate> 下午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;    
}   


^_^
分享到:
评论

相关推荐

    WEBLOGIC 常规服务器挂起问题.doc

    【WEBLOGIC服务器挂起问题详解】 WebLogic服务器作为Oracle公司的一款企业级Java应用服务器,其稳定性和性能至关重要。然而,在运行过程中,服务器可能会遇到挂起的问题,这会导致服务响应变慢甚至完全不响应新的...

    WEBLOGIC门户挂起分析

    总结:在分析和解决WEBLOGIC门户系统挂起问题时,需要关注数据库连接池的管理、系统资源限制、JVM内存配置、日志管理、JDBC线程池优化、错误日志分析、目录权限以及应用程序代码质量等多个方面。通过对这些环节的...

    weblogic8.1安装包

    WebLogic Server 8.1是Oracle公司开发的一款企业级应用服务器,它在Java平台上提供了一个用于构建、部署和管理分布式应用程序的平台。WebLogic Server 8.1的安装过程是IT管理员和开发者需要掌握的关键技能之一,因为...

    WebLogic宕机大全总结

    然而,在实际生产环境中,WebLogic Server可能会遭遇各种故障,其中最为常见的就是服务器宕机或挂起的问题。本文旨在通过分析实际案例来总结WebLogic宕机的原因及应对措施,以期为企业运维人员提供参考。 #### 二、...

    WebLogic服务器管理概述

    6. **管理服务器与受管服务器的启动和错误处理**:启动管理服务器时可能出现错误,这些错误信息会显示在控制台或日志文件中。WebLogic管理服务器可以通过命令行、脚本或Windows服务方式启动和停止。受管服务器的启动...

    weblogic集群配置多服务器版

    ### WebLogic 集群配置详解 #### 一、WebLogic 集群...综上所述,通过上述步骤,我们可以成功地在 WebLogic Portal 9.2 上配置一个多服务器集群。这种集群不仅能够提高系统的稳定性和性能,还能简化管理和维护工作。

    配置 MyEclipse 的 WebLogic 9 服务器

    ### 配置 MyEclipse 的 WebLogic 9 服务器 #### WebLogic 9.2 的基本配置步骤 在深入探讨如何在 MyEclipse 中配置 WebLogic 9 服务器之前,让我们先简要回顾一下 WebLogic 9.2 的基本配置过程。 1. **启动配置...

    BEA WebLogic 服务器管理

    【BEA WebLogic 服务器管理】是针对BEA Systems公司的WebLogic Server的管理和运维操作进行详细阐述的主题。WebLogic Server是一款流行的Java应用服务器,用于构建和部署企业级的分布式应用程序。在BEA WebLogic的...

    WebLogic-Web服务器安全配置基线.doc

    5.1.3 错误页面处理:错误页面处理是指对 WebLogic Web 服务器的错误页面处理,包括错误页面显示、错误日志等。 5.1.4 目录列表访问限制:目录列表访问限制是指对 WebLogic Web 服务器的目录列表访问限制,包括目录...

    Weblogic创建JMS服务器

    WebLogic Server是一款由Oracle公司提供的企业级Java应用服务器,它支持Java EE标准并提供各种服务,包括JMS(Java Message Service)服务器。JMS是一种在分布式环境中传递消息的标准API,它允许应用程序创建、发送...

    BEA.WebLogic.Platform.8.1实战指南.part04.rar

    part01-part08

    weblogic服务器基础使用手册

    《WebLogic服务器基础使用手册》 WebLogic服务器是一款由甲骨文公司开发的企业级Java应用服务器,广泛应用于企业级应用程序部署和管理。本文将详细介绍WebLogic服务器的基础使用,包括信息查看、日志查看、服务器...

    Linux安装WebLogic-服务器安装文档.docx

    Linux安装WebLogic服务器安装文档 本文档提供了在Linux系统上安装WebLogic服务器的详细步骤,从安装前的准备工作到安装、域的创建、服务的创建、集群管理的创建,以及相关配置详细说明。 安装前准备工作 1. 创建...

    配制Apahce作为Weblogic的前端服务器

    ### 配置Apache作为Weblogic的前端服务器 #### 一、Apache服务器的安装与配置 在开始配置Apache作为Weblogic的前端服务器之前,首先需要确保Apache服务器已经正确安装并运行。根据提供的内容,Apache可以从其官方...

    weblogic8.1服务器性能参数优化

    ### WebLogic 8.1 服务器性能参数优化详解 #### 一、概述 WebLogic 8.1 是一款成熟的企业级应用服务器,被广泛应用于构建高性能、高可用性的企业级应用。然而,为了确保WebLogic服务器能够高效稳定地运行,对其...

    WebLogicWeb服务器安全配置基线.doc

    【WebLogic Web服务器安全配置基线】 WebLogic Web服务器是中国移动通信某管理信息系统部的核心组件,主要用于提供企业管理信息系统的运行平台。为了确保系统的安全性,该文档制定了针对WebLogic Web服务器的详细...

    WebLogicWeb服务器安全配置基线.pdf

    WebLogic是甲骨文公司的一款企业级应用程序服务器,它提供了J2EE应用程序的完整实现,包括服务、中间件、管理和其他功能。WebLogic服务器广泛应用于开发、部署和管理大型分布式网络应用。考虑到WebLogic服务器部署...

Global site tag (gtag.js) - Google Analytics