我有一个在 tomcat 上运行的 java servlet 应用程序,并在 tomcat 中配置了 c3p0。我有一个应用程序,仅供我的组织中的少数人内部使用。通常只有 3 人或更少的人使用它,有时最多 5 人。所以,人数不是很多。通常,应用程序会意外地失败并出现以下错误。通常它会在长时间空闲(过夜)后发生,并在第二天的第一个请求时失败。我有其他具有类似堆栈的生产应用程序,没有这个问题,但它们很少闲置。这是错误(是的,我搜索过 stackoverflow 并看到其他人有类似的问题,但似乎没有一个解决方案适合我):
WARNING: com.mchange.v2.async.ThreadPoolAsynchronousRunner$DeadlockDetector@2a3252ed -- APPARENT DEADLOCK!!! Creating emergency threads for unassigned pending tasks!
Mar 19, 2014 6:42:11 AM com.mchange.v2.async.ThreadPoolAsynchronousRunner$DeadlockDetector run
WARNING: com.mchange.v2.async.ThreadPoolAsynchronousRunner$DeadlockDetector@2a3252ed -- APPARENT DEADLOCK!!! Complete Status:
Managed Threads: 3
Active Threads: 3
Active Tasks:
com.mchange.v2.resourcepool.BasicResourcePool$ScatteredAcquireTask@b7eed31
on thread: C3P0PooledConnectionPoolManager[identityToken->2ykl7d901mnvek411mheiv|3a7f5639]-HelperThread-#2
com.mchange.v2.resourcepool.BasicResourcePool$ScatteredAcquireTask@3a0631dc
on thread: C3P0PooledConnectionPoolManager[identityToken->2ykl7d901mnvek411mheiv|3a7f5639]-HelperThread-#1
com.mchange.v2.resourcepool.BasicResourcePool$ScatteredAcquireTask@6cb38046
on thread: C3P0PooledConnectionPoolManager[identityToken->2ykl7d901mnvek411mheiv|3a7f5639]-HelperThread-#0
Pending Tasks:
com.mchange.v2.resourcepool.BasicResourcePool$ScatteredAcquireTask@7caaab6a
com.mchange.v2.resourcepool.BasicResourcePool$ScatteredAcquireTask@28dbfc17
com.mchange.v2.resourcepool.BasicResourcePool$AsyncTestIdleResourceTask@2835ef6
com.mchange.v2.resourcepool.BasicResourcePool$AsyncTestIdleResourceTask@7ecf69c3
com.mchange.v2.resourcepool.BasicResourcePool$AsyncTestIdleResourceTask@6328c23f
com.mchange.v2.resourcepool.BasicResourcePool$AsyncTestIdleResourceTask@8e8e8f5
com.mchange.v2.resourcepool.BasicResourcePool$AsyncTestIdleResourceTask@73163164
com.mchange.v2.resourcepool.BasicResourcePool$1DestroyResourceTask@3604d743
com.mchange.v2.resourcepool.BasicResourcePool$1DestroyResourceTask@77d08b69
com.mchange.v2.resourcepool.BasicResourcePool$ScatteredAcquireTask@1c70d7f3
com.mchange.v2.resourcepool.BasicResourcePool$ScatteredAcquireTask@3471a11b
Pool thread stack traces:
Thread[C3P0PooledConnectionPoolManager[identityToken->2ykl7d901mnvek411mheiv|3a7f5639]-HelperThread-#2,5,main]
java.net.SocketInputStream.socketRead0(Native Method)
java.net.SocketInputStream.read(SocketInputStream.java:146)
com.mysql.jdbc.util.ReadAheadInputStream.fill(ReadAheadInputStream.java:114)
com.mysql.jdbc.util.ReadAheadInputStream.readFromUnderlyingStreamIfNecessary(ReadAheadInputStream.java:161)
com.mysql.jdbc.util.ReadAheadInputStream.read(ReadAheadInputStream.java:189)
com.mysql.jdbc.MysqlIO.readFully(MysqlIO.java:3116)
com.mysql.jdbc.MysqlIO.reuseAndReadPacket(MysqlIO.java:3573)
com.mysql.jdbc.MysqlIO.reuseAndReadPacket(MysqlIO.java:3562)
com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:4113)
com.mysql.jdbc.MysqlIO.sendCommand(MysqlIO.java:2570)
com.mysql.jdbc.MysqlIO.sqlQueryDirect(MysqlIO.java:2731)
com.mysql.jdbc.ConnectionImpl.execSQL(ConnectionImpl.java:2812)
com.mysql.jdbc.ConnectionImpl.execSQL(ConnectionImpl.java:2761)
com.mysql.jdbc.StatementImpl.executeQuery(StatementImpl.java:1612)
com.mysql.jdbc.ConnectionImpl.getTransactionIsolation(ConnectionImpl.java:3352)
com.mchange.v2.c3p0.impl.NewPooledConnection.<init>(NewPooledConnection.java:125)
com.mchange.v2.c3p0.WrapperConnectionPoolDataSource.getPooledConnection(WrapperConnectionPoolDataSource.java:211)
com.mchange.v2.c3p0.WrapperConnectionPoolDataSource.getPooledConnection(WrapperConnectionPoolDataSource.java:184)
com.mchange.v2.c3p0.impl.C3P0PooledConnectionPool$1PooledConnectionResourcePoolManager.acquireResource(C3P0PooledConnectionPool.java:200)
com.mchange.v2.resourcepool.BasicResourcePool.doAcquire(BasicResourcePool.java:1086)
com.mchange.v2.resourcepool.BasicResourcePool.doAcquireAndDecrementPendingAcquiresWithinLockOnSuccess(BasicResourcePool.java:1073)
com.mchange.v2.resourcepool.BasicResourcePool.access$800(BasicResourcePool.java:44)
com.mchange.v2.resourcepool.BasicResourcePool$ScatteredAcquireTask.run(BasicResourcePool.java:1810)
com.mchange.v2.async.ThreadPoolAsynchronousRunner$PoolThread.run(ThreadPoolAsynchronousRunner.java:648)
Thread[C3P0PooledConnectionPoolManager[identityToken->2ykl7d901mnvek411mheiv|3a7f5639]-HelperThread-#1,5,main]
com.mchange.v2.async.ThreadPoolAsynchronousRunner$PoolThread.run(ThreadPoolAsynchronousRunner.java:672)
Thread[C3P0PooledConnectionPoolManager[identityToken->2ykl7d901mnvek411mheiv|3a7f5639]-HelperThread-#0,5,main]
com.mchange.v2.async.ThreadPoolAsynchronousRunner$PoolThread.run(ThreadPoolAsynchronousRunner.java:672)
这是我在 tomcat 中的配置。 “capslock”中的项目已更改以保护无辜者:
<Resource name="jdbc/NAME_HERE" auth="Container"
description="DESCRIPTION"
jdbcUrl="jdbc:mysql://PATH_TO_RDS?autoReconnect=true"
user="USER"
password="PASS"
type="com.mchange.v2.c3p0.ComboPooledDataSource"
factory="org.apache.naming.factory.BeanFactory"
driverClass="com.mysql.jdbc.Driver"
maxPoolSize="50"
minPoolSize="10"
acquireIncrement="5"
acquireRetryAttempts="0"
acquireRetryDelay="3000"
breakAfterAcquireFailure="false"
maxConnectionAge="60"
maxIdleTime="30"
maxIdleTimeExcessConnections="10"
idleConnectionTestPeriod="15"
testConnectionOnCheckout="true"
preferredTestQuery="SELECT 1"
debugUnreturnedConnectionStackTraces="true"
autoCommitOnClose="true"
/>
我在服务器上使用 C3P0 0.9.2.1、mchange 0.2.3.4 和 mysql 连接器 5.1.26。我还在应用程序中使用 hibernate 3.2.5.ga。
我不知道这是否重要,但我们使用 Amazon 的 RDS,因此它不在本地主机上。
如有任何帮助,我们将不胜感激。这种情况已经持续了一段时间,我尝试了在各个论坛上可以找到的所有方法,但没有成功。
最佳答案
只是为了提供一个答案,这一切都是 JVM 内存问题。 JVM 会在一夜之间耗尽内存。我不知道为什么,但这台服务器为 tomcat 打开了一些特殊的垃圾收集器选项,当我删除这些选项时,不仅问题消失了,而且该机器上的内存占用量也小了很多。默认的垃圾收集器必须比正在使用的垃圾收集器更积极。这个问题已经好几个星期没有出现了,而且我认为与 c3p0 无关。 C3P0 只是发现并报告问题的一个。
关于java - 服务器整夜闲置后 C3P0 死锁,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22513152/