From 03f8f839353a8062ff47f38249eaef448540f1fb Mon Sep 17 00:00:00 2001 From: Clebert Suconic Date: Wed, 27 Jan 2021 17:40:10 -0500 Subject: [PATCH] ARTEMIS-3084 Small tweak. Log a Thread dump if a server.stop cannot get a completion of pending closes --- .../artemis/core/io/aio/AIOSequentialFileFactory.java | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/artemis-journal/src/main/java/org/apache/activemq/artemis/core/io/aio/AIOSequentialFileFactory.java b/artemis-journal/src/main/java/org/apache/activemq/artemis/core/io/aio/AIOSequentialFileFactory.java index e1cb2d6e6b..6b3c600ec8 100644 --- a/artemis-journal/src/main/java/org/apache/activemq/artemis/core/io/aio/AIOSequentialFileFactory.java +++ b/artemis-journal/src/main/java/org/apache/activemq/artemis/core/io/aio/AIOSequentialFileFactory.java @@ -18,6 +18,8 @@ package org.apache.activemq.artemis.core.io.aio; import java.io.File; import java.io.IOException; +import java.lang.management.ManagementFactory; +import java.lang.management.ThreadInfo; import java.nio.ByteBuffer; import java.util.Queue; import java.util.concurrent.ConcurrentLinkedQueue; @@ -303,6 +305,10 @@ public final class AIOSequentialFileFactory extends AbstractSequentialFileFactor // if we stop libaioContext before we finish this, we will never get confirmation on items previously sent if (!pendingClose.await(1, TimeUnit.MINUTES)) { ActiveMQJournalLogger.LOGGER.warn("Timeout on waiting for asynchronous close"); + final ThreadInfo[] threads = ManagementFactory.getThreadMXBean().dumpAllThreads(true, true); + for (ThreadInfo threadInfo : threads) { + ActiveMQJournalLogger.LOGGER.warn(threadInfo.toString()); + } } } catch (Throwable throwableToLog) { logger.warn(throwableToLog.getMessage(), throwableToLog);