Мы создаем соединение DB, используя JNDI
с объединением пулов BoneCP
. Через некоторое время bonecp создает больше com.google.common.base.internal.Finalizer
, bonecp-pool-watch-thread
и bonecp-keep-alive-scheduler
активных потоков. Поэтому требуется больше памяти. Это приводит к сбою JVM.Bonecp создает больше потоков bonecp-pool-watch-thread и bonecp-keep-alive-scheduler
Как исправить эту проблему? Любая конфигурация для управления количеством потоков.
Название: BoneCP бассейн-часы-нить
State: WAITING on java.u[email protected]42256c51
Total blocked: 0 Total waited: 1
Stack trace:
sun.misc.Unsafe.park(Native Method)
java.util.concurrent.locks.LockSupport.park(LockSupport.java:186)
java.util.concurrent.locks.AbstractQueuedSynchronizer$ConditionObject.await(AbstractQueuedSynchronizer.java:2043)
java.util.concurrent.ArrayBlockingQueue.take(ArrayBlockingQueue.java:374)
com.jolbox.bonecp.PoolWatchThread.run(PoolWatchThread.java:64)
java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145)
java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615)
java.lang.Thread.run(Thread.java:744)
Имя: com.google.common.base.internal.Finalizer
State: WAITING on [email protected]
Total blocked: 0 Total waited: 1
Stack trace:
java.lang.Object.wait(Native Method)
java.lang.ref.ReferenceQueue.remove(ReferenceQueue.java:135)
java.lang.ref.ReferenceQueue.remove(ReferenceQueue.java:151)
com.google.common.base.internal.Finalizer.run(Finalizer.java:131)
java.lang.Thread.run(Thread.java:744)
Имя: BoneCP продолжай -alive-scheduler
State: TIMED_WAITING on java.u[email protected]327a219f
Total blocked: 0 Total waited: 5
Stack trace:
sun.misc.Unsafe.park(Native Method)
java.util.concurrent.locks.LockSupport.parkNanos(LockSupport.java:226)
java.util.concurrent.locks.AbstractQueuedSynchronizer$ConditionObject.awaitNanos(AbstractQueuedSynchronizer.java:2082)
java.util.concurrent.ScheduledThreadPoolExecutor$DelayedWorkQueue.take(ScheduledThreadPoolExecutor.java:1090)
java.util.concurrent.ScheduledThreadPoolExecutor$DelayedWorkQueue.take(ScheduledThreadPoolExecutor.java:807)
java.util.concurrent.ThreadPoolExecutor.getTask(ThreadPoolExecutor.java:1068)
java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1130)
java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615)
java.lang.Thread.run(Thread.java:744)