Prefer Log4J2 over Log4J1 for default InternalLoggerFactory (#9734)

##Motivation

The InternalLoggerFactory attempts to instantiate different logger
implementations to discover what is available on the class path,
accepting the first implementation that does not throw an exception.

Currently, the default ordering will attempt to instantiate a Log4j1
logger before Log4j2. For environments where both Log4j1 and Log4j2 are
available, this will result in using the older version. It seems that it
would be more intuitive to prefer the newer version, when possible.

##Modifications

Change the default ordering to attempt to use the Log4J2LoggerFactory
before the Log4JLoggerFactory.

##Result

For environments where both Log4j1 and Log4j2 are available on the class
path (but Slf4J is not available), Netty will now use Log4j2 instead of
Log4j1.
This commit is contained in:
Bennett Lynch 2019-10-30 11:35:28 -07:00 committed by Norman Maurer
parent db84735975
commit 47f82b6b20

View File

@ -44,13 +44,13 @@ public abstract class InternalLoggerFactory {
f = new Slf4JLoggerFactory(true); f = new Slf4JLoggerFactory(true);
f.newInstance(name).debug("Using SLF4J as the default logging framework"); f.newInstance(name).debug("Using SLF4J as the default logging framework");
} catch (Throwable ignore1) { } catch (Throwable ignore1) {
try {
f = Log4JLoggerFactory.INSTANCE;
f.newInstance(name).debug("Using Log4J as the default logging framework");
} catch (Throwable ignore2) {
try { try {
f = Log4J2LoggerFactory.INSTANCE; f = Log4J2LoggerFactory.INSTANCE;
f.newInstance(name).debug("Using Log4J2 as the default logging framework"); f.newInstance(name).debug("Using Log4J2 as the default logging framework");
} catch (Throwable ignore2) {
try {
f = Log4JLoggerFactory.INSTANCE;
f.newInstance(name).debug("Using Log4J as the default logging framework");
} catch (Throwable ignore3) { } catch (Throwable ignore3) {
f = JdkLoggerFactory.INSTANCE; f = JdkLoggerFactory.INSTANCE;
f.newInstance(name).debug("Using java.util.logging as the default logging framework"); f.newInstance(name).debug("Using java.util.logging as the default logging framework");