Class AsyncAppender

  • All Implemented Interfaces:
    Appender, AppenderAttachable, OptionHandler

    public class AsyncAppender
    extends AppenderSkeleton
    implements AppenderAttachable
    The AsyncAppender lets users log events asynchronously.

    The AsyncAppender will collect the events sent to it and then dispatch them to all the appenders that are attached to it. You can attach multiple appenders to an AsyncAppender.

    The AsyncAppender uses a separate thread to serve the events in its buffer.

    Important note: The AsyncAppender can only be script configured using the DOMConfigurator.

    Since:
    0.9.1
    • Field Detail

      • DEFAULT_BUFFER_SIZE

        public static final int DEFAULT_BUFFER_SIZE
        The default buffer size is set to 128 events.
        See Also:
        Constant Field Values
      • buffer

        private final java.util.List buffer
        Event buffer, also used as monitor to protect itself and discardMap from simulatenous modifications.
      • discardMap

        private final java.util.Map discardMap
        Map of DiscardSummary objects keyed by logger name.
      • bufferSize

        private int bufferSize
        Buffer size.
      • dispatcher

        private final java.lang.Thread dispatcher
        Dispatcher.
      • locationInfo

        private boolean locationInfo
        Should location info be included in dispatched messages.
      • blocking

        private boolean blocking
        Does appender block when buffer is full.
    • Constructor Detail

      • AsyncAppender

        public AsyncAppender()
        Create new instance.
    • Method Detail

      • addAppender

        public void addAppender​(Appender newAppender)
        Add appender.
        Specified by:
        addAppender in interface AppenderAttachable
        Parameters:
        newAppender - appender to add, may not be null.
      • close

        public void close()
        Close this AsyncAppender by interrupting the dispatcher thread which will process all pending events before exiting.
        Specified by:
        close in interface Appender
      • getAllAppenders

        public java.util.Enumeration getAllAppenders()
        Get iterator over attached appenders.
        Specified by:
        getAllAppenders in interface AppenderAttachable
        Returns:
        iterator or null if no attached appenders.
      • getAppender

        public Appender getAppender​(java.lang.String name)
        Get appender by name.
        Specified by:
        getAppender in interface AppenderAttachable
        Parameters:
        name - name, may not be null.
        Returns:
        matching appender or null.
      • getLocationInfo

        public boolean getLocationInfo()
        Gets whether the location of the logging request call should be captured.
        Returns:
        the current value of the LocationInfo option.
      • isAttached

        public boolean isAttached​(Appender appender)
        Determines if specified appender is attached.
        Specified by:
        isAttached in interface AppenderAttachable
        Parameters:
        appender - appender.
        Returns:
        true if attached.
      • requiresLayout

        public boolean requiresLayout()
        Configurators call this method to determine if the appender requires a layout. If this method returns true, meaning that layout is required, then the configurator will configure an layout using the configuration information at its disposal. If this method returns false, meaning that a layout is not required, then layout configuration will be skipped even if there is available layout configuration information at the disposal of the configurator..

        In the rather exceptional case, where the appender implementation admits a layout but can also work without it, then the appender should return true.

        Specified by:
        requiresLayout in interface Appender
      • removeAppender

        public void removeAppender​(java.lang.String name)
        Remove appender by name.
        Specified by:
        removeAppender in interface AppenderAttachable
        Parameters:
        name - name.
      • setLocationInfo

        public void setLocationInfo​(boolean flag)
        The LocationInfo option takes a boolean value. By default, it is set to false which means there will be no effort to extract the location information related to the event. As a result, the event that will be ultimately logged will likely to contain the wrong location information (if present in the log format).

        Location information extraction is comparatively very slow and should be avoided unless performance is not a concern.

        Parameters:
        flag - true if location information should be extracted.
      • setBufferSize

        public void setBufferSize​(int size)
        Sets the number of messages allowed in the event buffer before the calling thread is blocked (if blocking is true) or until messages are summarized and discarded. Changing the size will not affect messages already in the buffer.
        Parameters:
        size - buffer size, must be positive.
      • getBufferSize

        public int getBufferSize()
        Gets the current buffer size.
        Returns:
        the current value of the BufferSize option.
      • setBlocking

        public void setBlocking​(boolean value)
        Sets whether appender should wait if there is no space available in the event buffer or immediately return.
        Parameters:
        value - true if appender should wait until available space in buffer.
        Since:
        1.2.14
      • getBlocking

        public boolean getBlocking()
        Gets whether appender should block calling thread when buffer is full. If false, messages will be counted by logger and a summary message appended after the contents of the buffer have been appended.
        Returns:
        true if calling thread will be blocked when buffer is full.
        Since:
        1.2.14