- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
我们的项目有一个 [Hibernate + c3p0 + MySQL] 配置。我们遇到了以下异常:
com.mchange.v2.resourcepool.CannotAcquireResourceException: A ResourcePool could not acquire a resource from its primary factory or source.
at com.mchange.v2.resourcepool.BasicResourcePool.awaitAvailable(BasicResourcePool.java:1319) ~[c3p0-0.9.1.2.jar:0.9.1.2]
at com.mchange.v2.resourcepool.BasicResourcePool.prelimCheckoutResource(BasicResourcePool.java:557) ~[c3p0-0.9.1.2.jar:0.9.1.2]
at com.mchange.v2.resourcepool.BasicResourcePool.checkoutResource(BasicResourcePool.java:477) ~[c3p0-0.9.1.2.jar:0.9.1.2]
at com.mchange.v2.c3p0.impl.C3P0PooledConnectionPool.checkoutPooledConnection(C3P0PooledConnectionPool.java:525) ~[c3p0-0.9.1.2.jar:0.9.1.2]
Wrapped by: java.sql.SQLException: Connections could not be acquired from the underlying database!
at com.mchange.v2.sql.SqlUtils.toSQLException(SqlUtils.java:106) ~[c3p0-0.9.1.2.jar:0.9.1.2]
at com.mchange.v2.c3p0.impl.C3P0PooledConnectionPool.checkoutPooledConnection(C3P0PooledConnectionPool.java:529) ~[c3p0-0.9.1.2.jar:0.9.1.2]
at com.mchange.v2.c3p0.impl.AbstractPoolBackedDataSource.getConnection(AbstractPoolBackedDataSource.java:128) ~[c3p0-0.9.1.2.jar:0.9.1.2]
at org.hibernate.service.jdbc.connections.internal.DatasourceConnectionProviderImpl.getConnection(DatasourceConnectionProviderImpl.java:141) ~[hibernate-core-4.0.1.Final.jar:4.0.1.Final]
at org.hibernate.internal.AbstractSessionImpl$NonContextualJdbcConnectionAccess.obtainConnection(AbstractSessionImpl.java:276) ~[hibernate-core-4.0.1.Final.jar:4.0.1.Final]
at org.hibernate.engine.jdbc.internal.LogicalConnectionImpl.obtainConnection(LogicalConnectionImpl.java:297) ~[hibernate-core-4.0.1.Final.jar:4.0.1.Final]
Wrapped by: org.hibernate.exception.GenericJDBCException: Could not open connection
at org.hibernate.exception.internal.StandardSQLExceptionConverter.convert(StandardSQLExceptionConverter.java:52) ~[hibernate-core-4.0.1.Final.jar:4.0.1.Final]
at org.hibernate.engine.jdbc.spi.SqlExceptionHelper.convert(SqlExceptionHelper.java:125) ~[hibernate-core-4.0.1.Final.jar:4.0.1.Final]
at org.hibernate.engine.jdbc.spi.SqlExceptionHelper.convert(SqlExceptionHelper.java:110) ~[hibernate-core-4.0.1.Final.jar:4.0.1.Final]
at org.hibernate.engine.jdbc.internal.LogicalConnectionImpl.obtainConnection(LogicalConnectionImpl.java:304) ~[hibernate-core-4.0.1.Final.jar:4.0.1.Final]
at org.hibernate.engine.jdbc.internal.LogicalConnectionImpl.getConnection(LogicalConnectionImpl.java:169) ~[hibernate-core-4.0.1.Final.jar:4.0.1.Final]
at org.hibernate.engine.transaction.internal.jdbc.JdbcTransaction.doBegin(JdbcTransaction.java:67) ~[hibernate-core-4.0.1.Final.jar:4.0.1.Final]
at org.hibernate.engine.transaction.spi.AbstractTransactionImpl.begin(AbstractTransactionImpl.java:160) ~[hibernate-core-4.0.1.Final.jar:4.0.1.Final]
at org.hibernate.internal.SessionImpl.beginTransaction(SessionImpl.java:1263) ~[hibernate-core-4.0.1.Final.jar:4.0.1.Final]
at org.springframework.orm.hibernate4.HibernateTransactionManager.doBegin(HibernateTransactionManager.java:399) ~[spring-orm-3.1.2.RELEASE.jar:3.1.2.RELEASE]
Wrapped by: org.springframework.transaction.CannotCreateTransactionException: Could not open Hibernate Session for transaction; nested exception is org.hibernate.exception.GenericJDBCException: Could not open connection
at org.springframework.orm.hibernate4.HibernateTransactionManager.doBegin(HibernateTransactionManager.java:440) ~[spring-orm-3.1.2.RELEASE.jar:3.1.2.RELEASE]
at org.springframework.transaction.support.AbstractPlatformTransactionManager.getTransaction(AbstractPlatformTransactionManager.java:371) ~[spring-tx-3.1.2.RELEASE.jar:3.1.2.RELEASE]
at org.springframework.transaction.interceptor.TransactionAspectSupport.createTransactionIfNecessary(TransactionAspectSupport.java:336) ~[spring-tx-3.1.2.RELEASE.jar:3.1.2.RELEASE]
at org.springframework.transaction.interceptor.TransactionInterceptor.invoke(TransactionInterceptor.java:105) ~[spring-tx-3.1.2.RELEASE.jar:3.1.2.RELEASE]
at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:172) ~[spring-aop-3.1.2.RELEASE.jar:3.1.2.RELEASE]
at org.springframework.aop.framework.JdkDynamicAopProxy.invoke(JdkDynamicAopProxy.java:202) ~[spring-aop-3.1.2.RELEASE.jar:3.1.2.RELEASE]
at $Proxy28.messageExists(Unknown Source) ~[na:na]
我们的 c3p0 配置:
<bean id="provDataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource" destroy-method="close">
…
<property name="acquireIncrement" value="1" />
<property name="idleConnectionTestPeriod" value="100"/>
<property name="minPoolSize" value="5" />
<property name="maxPoolSize" value="50" />
<property name="maxIdleTime" value="1800" />
</bean>
请注意,我们还在这个 MySQL 实例之上配置了另一个类似的 c3p0 数据源。
谁能给我一些关于如何调试它的建议?
最佳答案
虽然没有严格回答你的问题,但我不想在评论中添加代码,因为评论中的代码不可读。
这是我项目中带有 C3P0 的 MySQL 配置示例。请注意所有额外参数以确保连接不会中断。 (最后我选择了 Postgres,因为它没有终止我的连接并且总体上更稳定,还必须重新测试与 select 1 的连接;不是很有效)
<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource"
destroy-method="close">
<property name="driverClass" value="${jdbc.driverClassName}"/>
<property name="jdbcUrl" value="${jdbc.url}"/>
<property name="properties">
<props>
<prop key="c3p0.minPoolSize">0</prop>
<prop key="hc3p0.maxPoolSize">1000</prop>
<prop key="hc3p0.timeout">3000</prop>
<prop key="c3p0.acquire_increment">10</prop>
<prop key="c3p0.max_statement">50</prop>
<prop key="hibernate.c3p0.idle_test_period">60</prop>
<prop key="c3p0.preferredTestQuery">SELECT 1;</prop>
<prop key="hibernate.c3p0.testConnectionOnCheckout">false</prop>
<prop key="user">${jdbc.username}</prop>
<prop key="password">${jdbc.password}</prop>
</props>
</property>
</bean>
关于java - c3p0 getConnection() 抛出异常 : A ResourcePool could not acquire a resource from its primary factory or source,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13482803/
我的 Hibernate 下有 MySQL,我还使用 c3p0-0.9.1 作为连接池。 在我的笔记本电脑上运行时(我的意思是在本地)我没有错误。但是当我在服务器上部署它时,我得到了这个异常: com
我正在尝试使用 jdbcTemplate 连接到 Java 中的数据库,但出现以下错误。我用 Google 搜索了很长时间,发现的所有解决方案都没有解决我的问题。我尝试了几种不同的数据库(SQLSer
我很难找到使用 Resources 和 resourcePools 所需的文档 - 我找不到“资源 API 文档”。 我想以编程方式创建(自定义类型的)静态资源,然后将这些资源添加到资源池中。创建资源
我很难找到使用 Resources 和 resourcePools 所需的文档 - 我找不到“资源 API 文档”。 我想以编程方式创建(自定义类型的)静态资源,然后将这些资源添加到资源池中。创建资源
, 我正在尝试将 docker mysql 与 hibernate 应用程序一起使用。我的 db.properties 是: hibernate.connection.username=root hi
WARN (BasicResourcePool.java:1841) - com.mchange.v2.resourcepool.BasicResourcePool$AcquireTask@5ccb7
我有一个应用程序可以并行插入数据库数据 block (从技术上讲,很多 native INSERT 查询都在 EntityManager 对象上执行)。 我现在正试图了解如何加速这些插入。数据库主机和
我在 tomcat 版本 7 上部署了一个 java 应用程序。对于数据源,我使用了连接到 mysql 数据库的 c3p0。它多年来一直运行良好,最近我开始收到此错误:“客户端在等待从 com.mch
我们的项目有一个 [Hibernate + c3p0 + MySQL] 配置。我们遇到了以下异常: com.mchange.v2.resourcepool.CannotAcquireResourceE
我们的项目有一个 [Hibernate + c3p0 + MySQL] 配置。我们遇到了以下异常: com.mchange.v2.resourcepool.CannotAcquireResourceE
当我尝试连接到如图所示设置的测试数据库时,我遇到了上述的所有错误。 大部分配置来自工作生产环境,但我无法连接到我的测试数据库。 我尝试了各种方法,但都无法正常运行。 我能够通过其他方法(例如 PLSQ
我正在使用一个移动网络应用程序,其中数据库部分我使用Hibernate,连接池c3p0,当我在开始工作正常,但是在执行了一些事务(例如选择、保存、更新)之后,我收到以下异常,我不知道为什么会发生, S
环境:服务器:Jboss 4.2.3.GA 我们使用 c3p0 0.9.1.2 作为连接池。 每当我们在 Jboss AS 中热部署 war 文件时,都会遇到来自 c3p0 的内存泄漏。它最终导致“j
环境:服务器:Jboss 4.2.3.GA 我们使用 c3p0 0.9.1.2 作为连接池。 每当我们在 Jboss AS 中热部署 war 文件时,都会遇到来自 c3p0 的内存泄漏。它最终导致“j
我是一名优秀的程序员,十分优秀!