Поток JBoss WorkManager в состоянии БЛОКИРОВАН
Мы используем JBoss 5 и JDK 1.6. Мы используем интеграцию Spring для опроса файлов из нескольких каталогов.
<file:inbound-channel-adapter id="flowInboundFileAdapter" directory="${service.integration.path}" scanner="recursiveScanner" filter="customPathFileFilter"
channel="myInChannel" auto-create-directory="false" auto-startup="true" prevent-duplicates="true" queue-size="10">
<poller max-messages-per-poll="10" fixed-rate="10" time-unit="SECONDS" task-executor="taskExecutor" />
</file:inbound-channel-adapter>
<beans:bean id="recursiveScanner" class="org.springframework.integration.file.RecursiveLeafOnlyDirectoryScanner" />
Мы только что поняли из дампа потока, что все потоки (198 из 200) заблокированы в.integration.file.filters.AcceptOnceFileListFilter.accept(AcceptOnceFileListFilter.java:60). Мы не уверены, что это тупик или что-то еще? как мы можем решить это? Можем ли мы убить их, не перезапуская JBoss?
Thread: WorkManager(2)-1 : priority:5, demon:true, threadId:71, threadState:WAITING
- waiting on <0x6b25d66e> (a java.util.concurrent.locks.AbstractQueuedSynchronizer$ConditionObject)
sun.misc.Unsafe.park(Native Method)
java.util.concurrent.locks.LockSupport.park(LockSupport.java:158)
java.util.concurrent.locks.AbstractQueuedSynchronizer$ConditionObject.await(AbstractQueuedSynchronizer.java:1987)
java.util.concurrent.PriorityBlockingQueue.take(PriorityBlockingQueue.java:220)
org.jboss.resource.adapter.mail.inflow.NewMsgsWorker.run(NewMsgsWorker.java:76)
org.jboss.resource.work.WorkWrapper.execute(WorkWrapper.java:205)
org.jboss.util.threadpool.BasicTaskWrapper.run(BasicTaskWrapper.java:260)
java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:886)
java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:908)
java.lang.Thread.run(Thread.java:662)
Locked synchronizers :
- locked <0x699f91ee> (a java.util.concurrent.locks.ReentrantLock$NonfairSync)
Thread: WorkManager(2)-2 : priority:5, demon:true, threadId:115, threadState:BLOCKED
- waiting on <0x1f3fd8f5> (a java.lang.Object)
org.springframework.integration.file.filters.AcceptOnceFileListFilter.accept(AcceptOnceFileListFilter.java:60)
org.springframework.integration.file.filters.AbstractFileListFilter.filterFiles(AbstractFileListFilter.java:39)
org.springframework.integration.file.filters.CompositeFileListFilter.filterFiles(CompositeFileListFilter.java:93)
org.springframework.integration.file.DefaultDirectoryScanner.listFiles(DefaultDirectoryScanner.java:69)
org.springframework.integration.file.FileReadingMessageSource.scanInputDirectory(FileReadingMessageSource.java:276)
org.springframework.integration.file.FileReadingMessageSource.receive(FileReadingMessageSource.java:250)
org.springframework.integration.endpoint.SourcePollingChannelAdapter.receiveMessage(SourcePollingChannelAdapter.java:111)
org.springframework.integration.endpoint.AbstractTransactionSynchronizingPollingEndpoint.doPoll(AbstractTransactionSynchronizingPollingEndpoint.java:67)
org.springframework.integration.endpoint.AbstractPollingEndpoint$1.call(AbstractPollingEndpoint.java:146)
org.springframework.integration.endpoint.AbstractPollingEndpoint$1.call(AbstractPollingEndpoint.java:144)
org.springframework.integration.endpoint.AbstractPollingEndpoint$Poller$1.run(AbstractPollingEndpoint.java:236)
org.springframework.integration.util.ErrorHandlingTaskExecutor$1.run(ErrorHandlingTaskExecutor.java:52)
com.dashboard.service.security.spring.SecurityContextAwareTaskExecutor$1.run(SecurityContextAwareTaskExecutor.java:26)
org.springframework.jca.work.DelegatingWork.run(DelegatingWork.java:57)
org.jboss.resource.work.WorkWrapper.execute(WorkWrapper.java:205)
org.jboss.util.threadpool.BasicTaskWrapper.run(BasicTaskWrapper.java:260)
java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:886)
java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:908)
java.lang.Thread.run(Thread.java:662)
Locked synchronizers :
- locked <0x12106b7> (a java.util.concurrent.locks.ReentrantLock$NonfairSync)
Thread: WorkManager(2)-3 : priority:5, demon:true, threadId:116, threadState:BLOCKED
- waiting on <0x1f3fd8f5> (a java.lang.Object)
org.springframework.integration.file.filters.AcceptOnceFileListFilter.accept(AcceptOnceFileListFilter.java:60)
org.springframework.integration.file.filters.AbstractFileListFilter.filterFiles(AbstractFileListFilter.java:39)
org.springframework.integration.file.filters.CompositeFileListFilter.filterFiles(CompositeFileListFilter.java:93)
org.springframework.integration.file.DefaultDirectoryScanner.listFiles(DefaultDirectoryScanner.java:69)
org.springframework.integration.file.FileReadingMessageSource.scanInputDirectory(FileReadingMessageSource.java:276)
org.springframework.integration.file.FileReadingMessageSource.receive(FileReadingMessageSource.java:250)
org.springframework.integration.endpoint.SourcePollingChannelAdapter.receiveMessage(SourcePollingChannelAdapter.java:111)
org.springframework.integration.endpoint.AbstractTransactionSynchronizingPollingEndpoint.doPoll(AbstractTransactionSynchronizingPollingEndpoint.java:67)
org.springframework.integration.endpoint.AbstractPollingEndpoint$1.call(AbstractPollingEndpoint.java:146)
org.springframework.integration.endpoint.AbstractPollingEndpoint$1.call(AbstractPollingEndpoint.java:144)
org.springframework.integration.endpoint.AbstractPollingEndpoint$Poller$1.run(AbstractPollingEndpoint.java:236)
org.springframework.integration.util.ErrorHandlingTaskExecutor$1.run(ErrorHandlingTaskExecutor.java:52)
com.dashboard.service.security.spring.SecurityContextAwareTaskExecutor$1.run(SecurityContextAwareTaskExecutor.java:26)
org.springframework.jca.work.DelegatingWork.run(DelegatingWork.java:57)
org.jboss.resource.work.WorkWrapper.execute(WorkWrapper.java:205)
org.jboss.util.threadpool.BasicTaskWrapper.run(BasicTaskWrapper.java:260)
java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:886)
java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:908)
java.lang.Thread.run(Thread.java:662)
Locked synchronizers :
- locked <0x4524fab4> (a java.util.concurrent.locks.ReentrantLock$NonfairSync)
1 ответ
Я думаю, у вас огромное количество файлов в каталоге; каждый раз, когда мы сканируем каталог, мы должны проверять каждый в фильтре.
Наличие чрезвычайно большого количества файлов приведет к снижению производительности.
Обычно лучше переименовывать / удалять файлы, когда вы их обработали.
Если вы не можете сделать это, вы можете попробовать новый WatchServiceDirectoryScanner. Который будет только получать новые файлы.