2015-03-21 2 views
1

Мы создаем соединение 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) 

ответ

0

Это связано с ошибкой библиотеки Guava. Однако, обратите внимание, что вы должны учитывать, что BoneCP устарел в пользу HikariCP.

Смежные вопросы