spring+hibernate配置c3p0无法释放数据库连接

弄了3天,还是没有搞定。
配置:
winxp+tomcat5.0.28+hibernate3.1+spring1.2.6+struts1.0+mysql5.0.17,做了一个小blog。没有配置连接池时,运转良好。用c3p0配置后,每次都会出现3或者5个新连接。然后发现数据库连接不能释放。出现很多sleep连接。直到全部连接占满。
出现:错误表现:
[code]javax.servlet.ServletException: Hibernate operation: Cannot open connection; uncategorized SQLException for SQL [???]; SQL state [null]; error code [0]; Connections could not be acquired from the underlying database!; nested exception is java.sql.SQLException: Connections could not be acquired from the underlying database[/code]
数据库的表现是:
[img]https://p-blog.csdn.net/images/p_blog_csdn_net/voff12/pool1.jpg[/img]
[b]类似的问题,但没有都没有很好的解决方法。[/b]
[quote]06-21-2006 spring论坛一问题。
[url]http://forum.springframework.org/showthread.php?t=26124[/url]
JavaEye
求助,Spring+Hibernate连接池无法释放问题,贴出详细代码
[url]http://www.iteye.com/topic/32378[/url][/quote]下面是applicationContext.xml的配置:
[code]<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE beans PUBLIC "-//SPRING//DTD BEAN//EN" "http://www.springframework.org/dtd/spring-beans.dtd">

<beans>

<!-- for properties files -->
<bean id="propertyConfigurer"
class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
<property name="locations">
<list>
<value>classpath:c3p0.properties</value>
</list>
</property>
</bean>

<!-- for dataSource -->
<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource" destroy-method="close">
<property name="driverClass" value="${jdbc.driver}" />
<property name="jdbcUrl" value="${jdbc.url}" />

<property name="properties">
<props>
<prop key="c3p0.minPoolSize">${hibernate.c3p0.minPoolSize}</prop>
<prop key="hc3p0.maxPoolSize">${hibernate.c3p0.maxPoolSize}</prop>
<prop key="hc3p0.timeout">${hibernate.c3p0.timeout}</prop>
<prop key="c3p0.max_statement">${hibernate.c3p0.max_statement}</prop>
<prop key="user">${jdbc.username}</prop>
<prop key="password">${jdbc.password}</prop>
<prop key="c3p0.testConnectionOnCheckout">true</prop>
</props>
</property>
</bean>


<bean id="sessionFactory"
class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">

<property name="dataSource">
<ref bean="dataSource" />
</property>
<property name="mappingResources">
<list>
<value>com/voff/hibernate/Blog.hbm.xml</value>
</list>
</property>
<property name="hibernateProperties">
<props>
<prop key="hibernate.dialect">
org.hibernate.dialect.MySQLDialect
</prop>
<prop key="hibernate.show_sql">
true
</prop>
<prop key="hibernate.connection.provider_class">
org.hibernate.connection.C3P0ConnectionProvider
</prop>
</props>
</property>
</bean>

<!-- transactionManager -->
<bean id="transactionManager" class="org.springframework.orm.hibernate3.HibernateTransactionManager">
<property name="sessionFactory">
<ref bean="sessionFactory"/>
</property>
</bean>

<bean id="BlogDao" class="com.voff.dao.BlogDaoimpl">
<property name="sessionFactory">
<ref bean="sessionFactory"/>
</property>
</bean>

<!-- spring dao proxy -->
<bean id="BlogDaoProxy" class="org.springframework.transaction.interceptor.TransactionProxyFactoryBean">
<property name="transactionManager">
<ref bean="transactionManager"/>
</property>
<property name="proxyInterfaces">
<list>
<value>com.voff.dao.BlogDao</value>
</list>
</property>
<property name="target">
<ref bean="BlogDao"/>
</property>
<property name="transactionAttributes">
<props>
<prop key="insert">PROPAGATION_REQUIRED</prop>
<prop key="save*">PROPAGATION_REQUIRED</prop>
<prop key="update*">PROPAGATION_REQUIRED</prop>
<prop key="find*">PROPAGATION_REQUIRED</prop>
<prop key="*">PROPAGATION_REQUIRED,readOnly</prop>
</props>
</property>

</bean>

</beans>[/code]
c3p0.properties的配置是:
[code]jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://localhost/spring?useUnicode=true&characterEncoding=UTF-8
jdbc.username=root
jdbc.password=

hibernate.c3p0.minPoolSize=5
hibernate.c3p0.maxPoolSize=20
hibernate.c3p0.timeout=100
hibernate.c3p0.max_statement=50[/code]

BlogDaoimpl的代码是:
[code]
package com.voff.dao;

import java.util.ArrayList;
import java.util.List;

import org.hibernate.Query;
import org.hibernate.Session;
import org.springframework.orm.hibernate3.support.HibernateDaoSupport;

import com.voff.hibernate.Blog;


public class BlogDaoimpl extends HibernateDaoSupport implements BlogDao{

public void addblog(Blog blog) {
getHibernateTemplate().save(blog);


}

public void delblog(int id) {

Object blog=getHibernateTemplate().load(Blog.class,id);
getHibernateTemplate().delete(blog);


}

public void updateblog(Blog blog) {
getHibernateTemplate().update(blog);


}

public Blog getblog(int id){
return (Blog) getHibernateTemplate().get(Blog.class,id);
}


public int Totallimitblog(int caid,String bauthor){
String sql = "from Blog where cateid='"+caid+"' and bauthor ='"+bauthor+"'";
List total = getHibernateTemplate().find(sql);

return total.size();
}

public ArrayList showblog(int firstRow,int maxRow,int caid,String bauthor){
List list=new ArrayList();

Session session = getHibernateTemplate().getSessionFactory().openSession();
Query query =session.createQuery("from Blog where cateid='"+caid+"' and bauthor ='"+bauthor+"' order by blogid desc");
query.setFirstResult(firstRow);
query.setMaxResults(maxRow);
list=query.list();
session.flush();
session.close();
return (ArrayList) list;
}


}[/code]
请各位高手帮我看看,到底是什么原因(连接池问题,还是代码问题(不用连接池运转良好)导致数据库sleep连接不能释放。谢谢!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值