Package org.apache.logging.log4j.core
Class Logger
java.lang.Object
org.apache.logging.log4j.spi.AbstractLogger
org.apache.logging.log4j.core.Logger
- All Implemented Interfaces:
- Serializable,- Supplier<LoggerConfig>,- Logger,- ExtendedLogger,- LocationAwareLogger,- Supplier<LoggerConfig>
- Direct Known Subclasses:
- AsyncLogger
The core implementation of the 
Logger interface. Besides providing an implementation
 of all the Logger methods, this class also provides some convenience methods for Log4j 1.x compatibility as well as
 access to the Filters and Appenders associated with this Logger. Note that access to these underlying objects is provided primarily for use in
 unit tests or bridging legacy Log4j 1.x code. Future versions of this class may or may not include the various
 methods that are noted as not being part of the public API.
 TODO All the isEnabled methods could be pushed into a filter interface. Not sure of the utility of having isEnabled
 be able to examine the message pattern and parameters. (RG) Moving the isEnabled methods out of Logger noticeably
 impacts performance. The message pattern and parameters are required so that they can be used in global filters.- See Also:
- 
Nested Class SummaryNested ClassesModifier and TypeClassDescriptionprotected static classSerialization proxy class for Logger.protected classThe binding between a Logger and its configuration.
- 
Field SummaryFieldsModifier and TypeFieldDescriptionprotected Logger.PrivateConfigConfig should be consistent across threads.Fields inherited from class org.apache.logging.log4j.spi.AbstractLoggerCATCHING_MARKER, DEFAULT_FLOW_MESSAGE_FACTORY_CLASS, DEFAULT_MESSAGE_FACTORY_CLASS, ENTRY_MARKER, EXCEPTION_MARKER, EXIT_MARKER, FLOW_MARKER, name, THROWING_MARKER
- 
Constructor SummaryConstructorsModifierConstructorDescriptionprotectedLogger(LoggerContext context, String name, MessageFactory messageFactory) Constructs an instance using the givenLoggerContext, logger name, andMessageFactory.protectedLogger(LoggerContext context, String name, MessageFactory messageFactory, FlowMessageFactory flowMessageFactory) The canonical constructor.
- 
Method SummaryModifier and TypeMethodDescriptionvoidaddAppender(Appender appender) This method is not exposed through the public API and is used primarily for unit testing.voidThis method is not exposed through the public API and is used primarily for unit testing.booleanintThis method is not exposed through the public API and is used primarily for unit testing.get()This method is not exposed through the public API and is used primarily for unit testing.Returns the LoggerContext this Logger is associated with.This method is not exposed through the public API and is used primarily for unit testing.getLevel()Gets the Level associated with the Logger.This method is only used for 1.x compatibility.inthashCode()booleanThis method is not exposed through the public API and is present only to support the Log4j 1.2 compatibility bridge.booleanisEnabled(Level level, Marker marker, CharSequence message, Throwable t) booleanbooleanbooleanbooleanbooleanbooleanbooleanbooleanisEnabled(Level level, Marker marker, String message, Object p0, Object p1, Object p2, Object p3, Object p4) booleanisEnabled(Level level, Marker marker, String message, Object p0, Object p1, Object p2, Object p3, Object p4, Object p5) booleanisEnabled(Level level, Marker marker, String message, Object p0, Object p1, Object p2, Object p3, Object p4, Object p5, Object p6) booleanisEnabled(Level level, Marker marker, String message, Object p0, Object p1, Object p2, Object p3, Object p4, Object p5, Object p6, Object p7) booleanisEnabled(Level level, Marker marker, String message, Object p0, Object p1, Object p2, Object p3, Object p4, Object p5, Object p6, Object p7, Object p8) booleanisEnabled(Level level, Marker marker, String message, Object p0, Object p1, Object p2, Object p3, Object p4, Object p5, Object p6, Object p7, Object p8, Object p9) booleanbooleanprotected voidlog(Level level, Marker marker, String fqcn, StackTraceElement location, Message message, Throwable throwable) voidvoidremoveAppender(Appender appender) This method is not exposed through the public API and is used primarily for unit testing.protected booleanvoidsetAdditive(boolean additive) This method is not exposed through the public API and is present only to support the Log4j 1.2 compatibility bridge.voidThis method is not exposed through the public API and is provided primarily for unit testing.toString()Returns a String representation of this instance in the form"name:level[ in context_name]".protected voidupdateConfiguration(Configuration newConfig) Associates this Logger with a new Configuration.protected ObjectMethods inherited from class org.apache.logging.log4j.spi.AbstractLoggeralways, atDebug, atError, atFatal, atInfo, atTrace, atWarn, catching, catching, catching, catchingMsg, checkMessageFactory, debug, debug, debug, debug, debug, debug, debug, debug, debug, debug, debug, debug, debug, debug, debug, debug, debug, debug, debug, debug, debug, debug, debug, debug, debug, debug, debug, debug, debug, debug, debug, debug, debug, debug, debug, debug, debug, debug, debug, debug, debug, debug, debug, debug, debug, debug, debug, debug, enter, enter, enter, enter, enter, entry, entry, entry, entryMsg, entryMsg, entryMsg, error, error, error, error, error, error, error, error, error, error, error, error, error, error, error, error, error, error, error, error, error, error, error, error, error, error, error, error, error, error, error, error, error, error, error, error, error, error, error, error, error, error, error, error, error, error, error, error, exit, exit, exit, exit, exitMsg, fatal, fatal, fatal, fatal, fatal, fatal, fatal, fatal, fatal, fatal, fatal, fatal, fatal, fatal, fatal, fatal, fatal, fatal, fatal, fatal, fatal, fatal, fatal, fatal, fatal, fatal, fatal, fatal, fatal, fatal, fatal, fatal, fatal, fatal, fatal, fatal, fatal, fatal, fatal, fatal, fatal, fatal, fatal, fatal, fatal, fatal, fatal, fatal, getFlowMessageFactory, getLogBuilder, getMessageFactory, getName, getRecursionDepth, info, info, info, info, info, info, info, info, info, info, info, info, info, info, info, info, info, info, info, info, info, info, info, info, info, info, info, info, info, info, info, info, info, info, info, info, info, info, info, info, info, info, info, info, info, info, info, info, isDebugEnabled, isDebugEnabled, isEnabled, isEnabled, isErrorEnabled, isErrorEnabled, isFatalEnabled, isFatalEnabled, isInfoEnabled, isInfoEnabled, isTraceEnabled, isTraceEnabled, isWarnEnabled, isWarnEnabled, log, log, log, log, log, log, log, log, log, log, log, log, log, log, log, log, log, log, log, log, log, log, log, log, log, log, log, log, log, log, log, log, log, log, log, log, log, log, log, log, log, log, log, log, log, log, log, log, logIfEnabled, logIfEnabled, logIfEnabled, logIfEnabled, logIfEnabled, logIfEnabled, logIfEnabled, logIfEnabled, logIfEnabled, logIfEnabled, logIfEnabled, logIfEnabled, logIfEnabled, logIfEnabled, logIfEnabled, logIfEnabled, logIfEnabled, logIfEnabled, logIfEnabled, logMessage, logMessage, logMessage, logMessage, logMessage, logMessage, logMessage, logMessage, logMessage, logMessage, logMessage, logMessage, logMessage, logMessage, logMessage, logMessage, logMessage, logMessage, logMessage, printf, printf, throwing, throwing, throwing, throwingMsg, trace, trace, trace, trace, trace, trace, trace, trace, trace, trace, trace, trace, trace, trace, trace, trace, trace, trace, trace, trace, trace, trace, trace, trace, trace, trace, trace, trace, trace, trace, trace, trace, trace, trace, trace, trace, trace, trace, trace, trace, trace, trace, trace, trace, trace, trace, trace, trace, traceEntry, traceEntry, traceEntry, traceEntry, traceEntry, traceExit, traceExit, traceExit, traceExit, traceExit, traceExit, warn, warn, warn, warn, warn, warn, warn, warn, warn, warn, warn, warn, warn, warn, warn, warn, warn, warn, warn, warn, warn, warn, warn, warn, warn, warn, warn, warn, warn, warn, warn, warn, warn, warn, warn, warn, warn, warn, warn, warn, warn, warn, warn, warn, warn, warn, warn, warn
- 
Field Details- 
privateConfigConfig should be consistent across threads.
 
- 
- 
Constructor Details- 
LoggerConstructs an instance using the givenLoggerContext, logger name, andMessageFactory.- Parameters:
- context- The- LoggerContextthis logger is associated with, never- null.
- name- The logger name, never- null.
- messageFactory- The message factory to be used. Passing a- nullvalue is deprecated, but supported for backward compatibility.
 
- 
Loggerprotected Logger(LoggerContext context, String name, MessageFactory messageFactory, FlowMessageFactory flowMessageFactory) The canonical constructor.- Parameters:
- context- The- LoggerContextthis logger is associated with, never- null.
- name- The logger name, never- null.
- messageFactory- The message factory to be used. Passing a- nullvalue is deprecated, but supported for backward compatibility.
- flowMessageFactory- The flow message factory to be used. Passing a- nullvalue is deprecated, but supported for backward compatibility.
 
 
- 
- 
Method Details- 
writeReplace- Throws:
- ObjectStreamException
 
- 
getParentThis method is only used for 1.x compatibility. Returns the parent of this Logger. If it doesn't already exist return a temporary Logger.- Returns:
- The parent Logger.
 
- 
getContextReturns the LoggerContext this Logger is associated with.- Returns:
- the LoggerContext.
 
- 
setLevelThis method is not exposed through the public API and is provided primarily for unit testing.If the new level is null, this logger inherits the level from its parent. - Parameters:
- level- The Level to use on this Logger, may be null.
 
- 
get- Specified by:
- getin interface- Supplier<LoggerConfig>
- Specified by:
- getin interface- Supplier<LoggerConfig>
 
- 
requiresLocationprotected boolean requiresLocation()- Overrides:
- requiresLocationin class- AbstractLogger
 
- 
logMessage- Specified by:
- logMessagein interface- ExtendedLogger
 
- 
logprotected void log(Level level, Marker marker, String fqcn, StackTraceElement location, Message message, Throwable throwable) - Overrides:
- login class- AbstractLogger
 
- 
isEnabled- Specified by:
- isEnabledin interface- ExtendedLogger
 
- 
isEnabled- Specified by:
- isEnabledin interface- ExtendedLogger
 
- 
isEnabled- Specified by:
- isEnabledin interface- ExtendedLogger
 
- 
isEnabled- Specified by:
- isEnabledin interface- ExtendedLogger
 
- 
isEnabled- Specified by:
- isEnabledin interface- ExtendedLogger
 
- 
isEnabledpublic boolean isEnabled(Level level, Marker marker, String message, Object p0, Object p1, Object p2) - Specified by:
- isEnabledin interface- ExtendedLogger
 
- 
isEnabledpublic boolean isEnabled(Level level, Marker marker, String message, Object p0, Object p1, Object p2, Object p3) - Specified by:
- isEnabledin interface- ExtendedLogger
 
- 
isEnabledpublic boolean isEnabled(Level level, Marker marker, String message, Object p0, Object p1, Object p2, Object p3, Object p4) - Specified by:
- isEnabledin interface- ExtendedLogger
 
- 
isEnabledpublic boolean isEnabled(Level level, Marker marker, String message, Object p0, Object p1, Object p2, Object p3, Object p4, Object p5) - Specified by:
- isEnabledin interface- ExtendedLogger
 
- 
isEnabledpublic boolean isEnabled(Level level, Marker marker, String message, Object p0, Object p1, Object p2, Object p3, Object p4, Object p5, Object p6) - Specified by:
- isEnabledin interface- ExtendedLogger
 
- 
isEnabledpublic boolean isEnabled(Level level, Marker marker, String message, Object p0, Object p1, Object p2, Object p3, Object p4, Object p5, Object p6, Object p7) - Specified by:
- isEnabledin interface- ExtendedLogger
 
- 
isEnabledpublic boolean isEnabled(Level level, Marker marker, String message, Object p0, Object p1, Object p2, Object p3, Object p4, Object p5, Object p6, Object p7, Object p8) - Specified by:
- isEnabledin interface- ExtendedLogger
 
- 
isEnabledpublic boolean isEnabled(Level level, Marker marker, String message, Object p0, Object p1, Object p2, Object p3, Object p4, Object p5, Object p6, Object p7, Object p8, Object p9) - Specified by:
- isEnabledin interface- ExtendedLogger
 
- 
isEnabled- Specified by:
- isEnabledin interface- ExtendedLogger
 
- 
isEnabled- Specified by:
- isEnabledin interface- ExtendedLogger
 
- 
isEnabled- Specified by:
- isEnabledin interface- ExtendedLogger
 
- 
addAppenderThis method is not exposed through the public API and is used primarily for unit testing.- Parameters:
- appender- The Appender to add to the Logger.
 
- 
removeAppenderThis method is not exposed through the public API and is used primarily for unit testing.- Parameters:
- appender- The Appender to remove from the Logger.
 
- 
getAppendersThis method is not exposed through the public API and is used primarily for unit testing.- Returns:
- A Map containing the Appender's name as the key and the Appender as the value.
 
- 
getFiltersThis method is not exposed through the public API and is used primarily for unit testing.- Returns:
- An Iterator over all the Filters associated with the Logger.
 
- 
getLevelGets the Level associated with the Logger.
- 
filterCountpublic int filterCount()This method is not exposed through the public API and is used primarily for unit testing.- Returns:
- The number of Filters associated with the Logger.
 
- 
addFilterThis method is not exposed through the public API and is used primarily for unit testing.- Parameters:
- filter- The Filter to add.
 
- 
isAdditivepublic boolean isAdditive()This method is not exposed through the public API and is present only to support the Log4j 1.2 compatibility bridge.- Returns:
- true if the associated LoggerConfig is additive, false otherwise.
 
- 
setAdditivepublic void setAdditive(boolean additive) This method is not exposed through the public API and is present only to support the Log4j 1.2 compatibility bridge.- Parameters:
- additive- Boolean value to indicate whether the Logger is additive or not.
 
- 
atLevel- Specified by:
- atLevelin interface- Logger
- Overrides:
- atLevelin class- AbstractLogger
 
- 
updateConfigurationAssociates this Logger with a new Configuration. This method is not exposed through the public API.There are two ways this could be used to guarantee all threads are aware of changes to config. - Synchronize this method. Accessors don't need to be synchronized as Java will treat all variables within a synchronized block as volatile.
- Declare the variable volatile. Option 2 is used here as the performance cost is very low and it does a better job at documenting how it is used.
 - Parameters:
- newConfig- The new Configuration.
 
- 
toStringReturns a String representation of this instance in the form"name:level[ in context_name]".
- 
equals
- 
hashCodepublic int hashCode()
 
-