From 2bca5371bd10269b3d3047be6fae32d66dff58c6 Mon Sep 17 00:00:00 2001 From: KOSEUNGBIN Date: Thu, 2 Jan 2025 19:10:02 +0900 Subject: [PATCH] Generate log message in advance (#3571) Add separate handling for Throwable when available. Fixes: #3561 Co-authored-by: Violeta Georgieva --- .../resources/PooledConnectionProvider.java | 31 ++++++++++++++----- 1 file changed, 24 insertions(+), 7 deletions(-) diff --git a/reactor-netty-core/src/main/java/reactor/netty/resources/PooledConnectionProvider.java b/reactor-netty-core/src/main/java/reactor/netty/resources/PooledConnectionProvider.java index 3b6d0f26ff..f1f020a9b0 100644 --- a/reactor-netty-core/src/main/java/reactor/netty/resources/PooledConnectionProvider.java +++ b/reactor-netty-core/src/main/java/reactor/netty/resources/PooledConnectionProvider.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2018-2024 VMware, Inc. or its affiliates, All Rights Reserved. + * Copyright (c) 2018-2025 VMware, Inc. or its affiliates, All Rights Reserved. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. @@ -55,6 +55,7 @@ import java.util.List; import java.util.Map; import java.util.Objects; +import java.util.StringJoiner; import java.util.concurrent.ConcurrentHashMap; import java.util.concurrent.ConcurrentMap; import java.util.concurrent.TimeUnit; @@ -365,13 +366,29 @@ protected static void logPoolState(Channel channel, InstrumentedPool pool, String msg, @Nullable Throwable t) { + String logMsg = msg + ", " + stringifyPoolMetrics(pool); + if (t == null) { + log.debug(format(channel, logMsg)); + return; + } + + log.debug( + format(channel, logMsg), + t + ); + } + + private static String stringifyPoolMetrics(InstrumentedPool pool) { InstrumentedPool.PoolMetrics metrics = pool.metrics(); - log.debug(format(channel, "{}, now: {} active connections, {} inactive connections and {} pending acquire requests."), - msg, - metrics.acquiredSize(), - metrics.idleSize(), - metrics.pendingAcquireSize(), - t == null ? "" : t); + return new StringJoiner(" ") + .add("now:") + .add(String.valueOf(metrics.acquiredSize())) + .add("active connections,") + .add(String.valueOf(metrics.idleSize())) + .add("inactive connections") + .add(String.valueOf(metrics.pendingAcquireSize())) + .add("pending acquire requests.") + .toString(); } final void scheduleInactivePoolsDisposal() {