事务完成后,C3P0未释放连接。 这是堆栈跟踪:
java.lang.Exception:DEBUG STACK TRACE:逾期资源签出堆栈跟踪。 在com.mchange.v2.resourcepool.BasicResourcePool.checkoutResource(BasicResourcePool.java:555) at com.mchange.v2.c3p0.impl.C3P0PooledConnectionPool.checkoutAndMarkConnectionInUse(C3P0PooledConnectionPool.java:755) at com.mchange.v2.c3p0.impl.C3P0PooledConnectionPool.checkoutPooledConnection(C3P0PooledConnectionPool.java:682) 在com.mchange.v2.c3p0.impl.AbstractPoolBackedDataSource.getConnection(AbstractPoolBackedDataSource.java:140) at org.hibernate.engine.jdbc.connections.internal.DatasourceConnectionProviderImpl.getConnection(DatasourceConnectionProviderImpl.java:122) at org.hibernate.internal.AbstractSessionImpl $ NonContextualJdbcConnectionAccess.obtainConnection(AbstractSessionImpl.java:386) at org.hibernate.resource.jdbc.internal.LogicalConnectionManagedImpl.acquireConnectionIfNeeded(LogicalConnectionManagedImpl.java:87) at org.hibernate.resource.jdbc.internal.LogicalConnectionManagedImpl.getPhysicalConnection(LogicalConnectionManagedImpl.java:112) at org.hibernate.engine.jdbc.internal.StatementPreparerImpl.connection(StatementPreparerImpl.java:47) 在org.hibernate.engine.jdbc.internal.StatementPreparerImpl $ 5.doPrepare(StatementPreparerImpl.java:146) at org.hibernate.engine.jdbc.internal.StatementPreparerImpl $ StatementPreparationTemplate.prepareStatement(StatementPreparerImpl.java:172) 在org.hibernate.engine.jdbc.internal.StatementPreparerImpl.prepareQueryStatement(StatementPreparerImpl.java:148)
............... at com.ikoda.dao.user.UserDaoImpl.getUserChildByEmailPassword(UserDaoImpl.java:329)
..................................... at com.ikoda.service.springtransactions.AdminUserServiceImpl.doUserChildLoginByEmail(AdminUserServiceImpl.java:100) 在com.ikoda.service.springtransactions.AdminUserServiceImpl.doLoginByEmail(AdminUserServiceImpl.java:89)
..........................
调用的服务方法如下:
@Transactional(readOnly = true, propagation = Propagation.REQUIRED)
public User doLoginByEmail(String email, String password) throws UserStructureException
{
User u = doUserMainLoginByEmail(email, password);
if (null != u)
{
return u;
}
else
{
return doUserChildLoginByEmail(email, password);
}
}
private UserMain doUserMainLoginByEmail(String email, String password) throws UserStructureException
{
try
{
UserMain returnedUser = userDao.getUserMainByEmailPassword(email, password, DeliveryPropertiesSingleton.getInstance().getBusinessId());
if (null != returnedUser && returnedUser.getPassword().equals(password))
{
return returnedUser;
}
return null;
}
catch (IndexOutOfBoundsException ioe)
{
...
}
catch (Exception e)
{
...
}
}
private UserChild doUserChildLoginByEmail(String email, String password) throws UserStructureException
{
try
{
UserChild returnedUser = userDao.getUserChildByEmailPassword(email, password, DeliveryPropertiesSingleton.getInstance().getBusinessId());
if (null != returnedUser && returnedUser.getPassword().equals(password))
{
return returnedUser;
}
return null;
}
catch (IndexOutOfBoundsException ioe)
{
...
}
catch (Exception e)
{
....
}
}
dao方法如下:
@Transactional(propagation = Propagation.MANDATORY)
public UserMain getUserMainByEmailPassword(String email, String password, Long businessId)
{
Session session = this.sessionFactory1.getCurrentSession();
List<UserMain> result = session.createQuery("from UserMain where email like '" + email + "' and password like '" + password + "' and businessid =" + businessId).list();
if(result.size()==1)
{
UserMain u = result.get(0);
return u;
}
return null;
}
@Transactional(propagation = Propagation.MANDATORY)
public UserChild getUserChildByEmailPassword(String email, String password, Long businessId)
{
Session session = this.sessionFactory1.openSession();
List<UserChild> result = session.createQuery("from UserChild where email like '" + email
+ "' and password like '" + password + "' and businessid =" + businessId).list();
if(result.size()==1)
{
UserChild u = result.get(0);
return u;
}
return null;
}
池配置和事务配置如下:
<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource"
destroy-method="close">
<property name="driverClass" value="org.postgresql.Driver" />
<property name="jdbcUrl" value="jdbc:postgresql://localhost/xxx?useUnicode=true&characterEncoding=utf8" />
<property name="user" value="xxx" />
<property name="password" value="xxxxxxx" />
<property name="acquireIncrement" value="2" />
<property name="minPoolSize" value="3" />
<property name="maxPoolSize" value="100" />
<property name="maxIdleTime" value="600" />
<property name="unreturnedConnectionTimeout" value="45" />
<property name="debugUnreturnedConnectionStackTraces" value="true" />
</bean>
&#13;
<bean id="transactionManager"
class="org.springframework.orm.hibernate5.HibernateTransactionManager">
<property name="sessionFactory" ref="sessionFactory1" />
</bean>
<tx:annotation-driven transaction-manager="transactionManager" />
&#13;
任何建议都会受到高度赞赏
答案 0 :(得分:0)
好的,死的很简单。
DAO方法使用openSession,需要显式关闭。对于spring / hibernate事务管理持久性,它应该是getCurrentSession