志当存高远,功到自然成!

少年强则中国强,少年进步则中国进步!

BlogJava 首页 新随笔 联系 聚合 管理
  53 Posts :: 2 Stories :: 2 Comments :: 0 Trackbacks

 

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

出现错误如下:

[2007-9-30 下午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.]

<转为[,>转为],才发得出以上面错误。可能是javaeye的bug。 

先说下我配置

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

xml 代码
  1. <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">  
  2.     <property name="driverClassName" value="${jdbc.driverClassName}"/>  
  3.     <property name="url" value="${jdbc.url}"/>  
  4.     <property name="username" value="${jdbc.username}"/>  
  5.     <property name="password" value="${jdbc.password}"/>  
  6. bean>  

 3.分页方法(参考springside的),此类继承HibernateDaoSupport

java 代码
  1. public Page listByPage(Class entityClass, int pageNo, int pageSize, List criterions, List orders) {   
  2.     Criteria criteria = createCriteria(entityClass, criterions);   
  3.     CriteriaImpl impl = (CriteriaImpl) criteria;   
  4.   
  5.     // 先把Projection和OrderBy条件取出来,清空两者来执行Count操作   
  6.     Projection projection = impl.getProjection();   
  7.     //获取总记录数   
  8.     int totalCount = ((Integer) criteria.setProjection(Projections.rowCount()).uniqueResult()).intValue();   
  9.   
  10.        
  11.     if(totalCount < 1) {   
  12.         return new Page();   
  13.     }   
  14.        
  15.     //加排序   
  16.     if(orders != null) {   
  17.         for(int i=0; i
  18.             criteria.addOrder((Order) orders.get(i));   
  19.         }   
  20.     }   
  21.     //原来的投影   
  22.     criteria.setProjection(projection);   
  23.     int startIndex = Page.getStartOfPage(pageNo, pageSize);   
  24.     //取得结果   
  25.     List list = criteria.setFirstResult(startIndex).setMaxResults(pageSize).list();   
  26.        
  27.     return new Page(startIndex, totalCount, pageSize, list);   
  28. }   
  29.   
  30. public Criteria createCriteria(Class entityClass, List criterions) {   
  31.     Criteria criteria = getSession().createCriteria(entityClass);   
  32.     if(criterions != null) {   
  33.         for(int i=0; i
  34.             criteria.add((Criterion) criterions.get(i));   
  35.         }   
  36.     }   
  37.        
  38.     return criteria;   
  39. }  

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

翻页不过10次,服务器就没响应了,最后出现上面的错误的了。



问题解决,问题的原因是数据库连接耗尽,我用HiberanteDaoSupport的getSession()方法取得Session后没有释放Session。

出问题的代码处:

java 代码
  1. public Criteria createCriteria(Class entityClass, List criterions) {       
  2.     Criteria criteria = getSession().createCriteria(entityClass);       
  3.     if(criterions != null) {       
  4.         for(int i=0; i    
  5.             criteria.add((Criterion) criterions.get(i));       
  6.         }       
  7.     }       
  8.            
  9.     return criteria;       
  10. }  

 

用完Session释放后就没事了,调用HiberanteDaoSupport的releaseSession(session);方法后即可解决。

现在正确的代码:

java 代码
  1. public Page listByPage(Class entityClass, int pageNo, int pageSize, List criterions, List orders) {   
  2.     Session session = getSession();   
  3.     //创建criteria   
  4.     Criteria criteria = session.createCriteria(entityClass);   
  5.     //为criteria添加criterions   
  6.     createCriteria(entityClass, criteria, criterions);   
  7.     CriteriaImpl impl = (CriteriaImpl) criteria;   
  8.   
  9.     // 先把Projection和OrderBy条件取出来,清空两者来执行Count操作   
  10.     Projection projection = impl.getProjection();   
  11.     //获取总记录数   
  12.     int totalCount = ((Integer) criteria.setProjection(Projections.rowCount()).uniqueResult()).intValue();   
  13.   
  14.        
  15.     if(totalCount < 1) {   
  16.         return new Page();   
  17.     }   
  18.        
  19.     //加排序   
  20.     if(orders != null) {   
  21.         for(int i=0; i<orders.size(); i++) {   
  22.             criteria.addOrder((Order) orders.get(i));   
  23.         }   
  24.     }   
  25.     //原来的投影   
  26.     criteria.setProjection(projection);   
  27.     int startIndex = Page.getStartOfPage(pageNo, pageSize);   
  28.     //取得结果   
  29.     List list = criteria.setFirstResult(startIndex).setMaxResults(pageSize).list();   
  30.     //释放hiberante资源,一定要释放,要不然就数据库连接耗尽.   
  31.     releaseSession(session);   
  32.     return new Page(startIndex, totalCount, pageSize, list);   
  33. }   
  34.   
  35. public Criteria createCriteria(Class entityClass, Criteria criteria, List criterions) {   
  36.     if(criterions != null) {   
  37.         for(int i=0; i<criterions.size(); i++) {   
  38.             criteria.add((Criterion) criterions.get(i));   
  39.         }   
  40.     }   
  41.        
  42.     return criteria;   
  43. }  

只有注册用户登录后才能发表评论。


网站导航: