- 浏览: 696542 次
- 性别:
- 来自: 杭州
文章分类
最新评论
前几天用spring+hibernate+struts写了个增/删/改/查的例子。调试期间问题就来了,当查询结果翻页好几次就没N久没有响应了。最后控制报错。网上查了,它说数据库连接(池)问题。
出现错误如下:
<<st1:chsdate w:st="on" isrocdate="False" islunardate="False" day="30" month="9" year="2007">2007-9-30</st1:chsdate> 下午12时03分03秒 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
<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
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。
出问题的代码处(红色部分):
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);方法后即可解决。
现在正确的代码:
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;
}
^_^
发表评论
-
不抛出越界异常的求子串方法
2008-06-18 14:36 1216用String.substring方法,不小心会有越界异 ... -
java -D参数简化加入多个jar
2008-05-30 11:22 1987java命令引入jar时可以-cp参数,但时-cp不 ... -
[原]自己实现的优先队列 PriorityQueue
2008-05-08 23:08 2099java库里的PriorityQueue无法满足我,它 ... -
poi会中文乱码,Jexcelapi不会
2007-03-21 19:06 2268目前比较流行的生成Excel文件的有poi和Jexcelapi ... -
itest生成pdf中文为空白
2007-03-21 19:52 2561要下载iTextAsian.jar地址: http://prd ... -
[转载]jsp 实现 word, excel
2007-08-22 13:15 1491这里使用一个小技巧,就是先将其转换为可编辑的JSP文件,然后再 ... -
jsp 提交表单中文问题解决
2007-09-09 09:47 1459用过虑器,但只对post有效,get方式请看。http ... -
Weblogic 中部署 Web 应用程序
2007-09-22 18:48 34181、安装好weblogic8.1 2、 ... -
weblogic8.1作为windows服务运行
2007-10-06 23:02 1650实验室机房里安装的Weblogic 每次想打开网页 ... -
jsp 下载文件
2007-10-16 23:57 2010jsp 直接输出二进制文件怎么办呢? downl ... -
java 压缩目录为 zip
2007-10-18 13:53 2110用java好久了,还没有写个压缩文件的示例,昨晚弄 ... -
jstl 1.0 formatDate yyyy-mm 不能正常工作
2007-10-25 22:38 1103jstl 1.0 formatDate yyyy-m ... -
jxl 写 excel
2007-10-29 10:52 1321项目中要写excel,把这个例子写出来,以后可以看 ... -
jxl 读 excel
2007-10-29 11:04 1461与写对应的是读. package net.bl ... -
ant build 出现 warning modified in the future
2007-12-13 23:13 1744今天同学想rebuild项目源码,但出现上面情况。 ... -
ant 编译特定包下面的源文件
2007-12-15 12:13 1711项目中有applet,现在想只编译applet包下 ... -
生产者-消费者
2008-01-24 11:36 1251这学期,应聘的时候有一些是线程相关的,虽然自己对线程编 ... -
Java读RTF乱码问题
2008-02-01 17:05 6897这几天想用Java读富文档。用javax.swing. ... -
System.in重复接收用户输入一行命令
2008-03-11 21:49 1647以前想用循环来System.in (或是其它输入方式老 ... -
下载文件保存提示文件名显示中文
2008-03-16 14:29 1191用URLEncoder转换。 String file ...
相关推荐
【WEBLOGIC服务器挂起问题详解】 WebLogic服务器作为Oracle公司的一款企业级Java应用服务器,其稳定性和性能至关重要。然而,在运行过程中,服务器可能会遇到挂起的问题,这会导致服务响应变慢甚至完全不响应新的...
.WEBLOGIC 常规服务器挂起问题.docx
.WEBLOGIC 常规服务器挂起问题.pdf
总结:在分析和解决WEBLOGIC门户系统挂起问题时,需要关注数据库连接池的管理、系统资源限制、JVM内存配置、日志管理、JDBC线程池优化、错误日志分析、目录权限以及应用程序代码质量等多个方面。通过对这些环节的...
WebLogic Server 8.1是Oracle公司开发的一款企业级应用服务器,它在Java平台上提供了一个用于构建、部署和管理分布式应用程序的平台。WebLogic Server 8.1的安装过程是IT管理员和开发者需要掌握的关键技能之一,因为...
总结,WebLogic独立服务器的配置和使用涉及到多个环节,包括安装、基本设置、数据源配置以及错误排查。理解并熟练掌握这些步骤对于高效地管理和维护WebLogic服务器至关重要。在实际操作中,遇到问题时,及时查阅文档...
然而,在实际生产环境中,WebLogic Server可能会遭遇各种故障,其中最为常见的就是服务器宕机或挂起的问题。本文旨在通过分析实际案例来总结WebLogic宕机的原因及应对措施,以期为企业运维人员提供参考。 #### 二、...
6. **管理服务器与受管服务器的启动和错误处理**:启动管理服务器时可能出现错误,这些错误信息会显示在控制台或日志文件中。WebLogic管理服务器可以通过命令行、脚本或Windows服务方式启动和停止。受管服务器的启动...
### WebLogic 集群配置详解 #### 一、WebLogic 集群...综上所述,通过上述步骤,我们可以成功地在 WebLogic Portal 9.2 上配置一个多服务器集群。这种集群不仅能够提高系统的稳定性和性能,还能简化管理和维护工作。
### 配置 MyEclipse 的 WebLogic 9 服务器 #### WebLogic 9.2 的基本配置步骤 在深入探讨如何在 MyEclipse 中配置 WebLogic 9 服务器之前,让我们先简要回顾一下 WebLogic 9.2 的基本配置过程。 1. **启动配置...
【BEA WebLogic 服务器管理】是针对BEA Systems公司的WebLogic Server的管理和运维操作进行详细阐述的主题。WebLogic Server是一款流行的Java应用服务器,用于构建和部署企业级的分布式应用程序。在BEA WebLogic的...
5.1.3 错误页面处理:错误页面处理是指对 WebLogic Web 服务器的错误页面处理,包括错误页面显示、错误日志等。 5.1.4 目录列表访问限制:目录列表访问限制是指对 WebLogic Web 服务器的目录列表访问限制,包括目录...
### Weblogic单服务器集群配置详解 #### 一、概述 Weblogic单服务器集群是指在一个物理服务器上部署多个Weblogic Server实例,形成一个集群环境。这种配置通常用于开发和测试环境中,以便于模拟真实世界中的高可用...
WebLogic Server是一款由Oracle公司提供的企业级Java应用服务器,它支持Java EE标准并提供各种服务,包括JMS(Java Message Service)服务器。JMS是一种在分布式环境中传递消息的标准API,它允许应用程序创建、发送...
part01-part08
《WebLogic服务器基础使用手册》 WebLogic服务器是一款由甲骨文公司开发的企业级Java应用服务器,广泛应用于企业级应用程序部署和管理。本文将详细介绍WebLogic服务器的基础使用,包括信息查看、日志查看、服务器...
Linux安装WebLogic服务器安装文档 本文档提供了在Linux系统上安装WebLogic服务器的详细步骤,从安装前的准备工作到安装、域的创建、服务的创建、集群管理的创建,以及相关配置详细说明。 安装前准备工作 1. 创建...
### 配置Apache作为Weblogic的前端服务器 #### 一、Apache服务器的安装与配置 在开始配置Apache作为Weblogic的前端服务器之前,首先需要确保Apache服务器已经正确安装并运行。根据提供的内容,Apache可以从其官方...