org.mule.module.launcher.log4j2.AsyncLoggerExceptionHandler Maven / Gradle / Ivy
/*
* Copyright (c) MuleSoft, Inc. All rights reserved. http://www.mulesoft.com
* The software in this package is published under the terms of the CPAL v1.0
* license, a copy of which has been included with this distribution in the
* LICENSE.txt file.
*/
package org.mule.module.launcher.log4j2;
import com.lmax.disruptor.ExceptionHandler;
import org.apache.logging.log4j.status.StatusLogger;
/**
* Implementation of {@link com.lmax.disruptor.ExceptionHandler} to be used
* when async loggers fail to log their messages. It will log this event
* using the {@link org.apache.logging.log4j.status.StatusLogger}
*
* @since 3.6.0
*/
public class AsyncLoggerExceptionHandler implements ExceptionHandler
{
private static final StatusLogger logger = StatusLogger.getLogger();
@Override
public void handleEventException(Throwable ex, long sequence, Object event)
{
logger.error("Failed to asynchronously log message: " + event, ex);
}
@Override
public void handleOnStartException(Throwable ex)
{
logger.error("Failed to start asynchronous logger", ex);
}
@Override
public void handleOnShutdownException(Throwable ex)
{
logger.error("Failed to stop asynchronous logger", ex);
}
}