Могу ли я использовать Logback.xml, чтобы поговорить с двумя регистраторами

Таким образом, мы имеем несколько уникальную ситуацию в том, что у нас есть регистратор компании, который создается с помощью LoggerFactory.getLogger и имени класса, а затем передается номер регистрации, исключаемое исключение и сообщение. Это идет в консоль администратора компании для мониторинга журналов.

Как команда, мы в настоящее время используем logback.xml для записи всех и всех сообщений журнала в файл, чтобы у нас была дополнительная информация. Вот наш logback.xml

    <?xml version="1.0" encoding="UTF-8"?>
<configuration debug="true">

    <statusListener class="ch.qos.logback.core.status.OnConsoleStatusListener" />  

    <!-- dev/log/BOSApplication_${byDate}.log -->
    <timestamp key="byDate" datePattern="yyyy-MM-dd" />




    <appender name="rollingFile" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <!-- <filter class="com.tdameritrade.commons.log.LogSuppressionFilter" /> -->
        <!--See also http://logback.qos.ch/manual/appenders.html#RollingFileAppender -->
        <File>../logs/BOSApplication_${byDate}.log</File>

        <encoder>
            <pattern>%date %-5level [%logger{36}:%F.%M:%L - %thread] - %msg%n</pattern>
        </encoder>

        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">

            <!-- rollover daily -->
            <FileNamePattern>../logs/BOSApplication_%d{yyyy-MM-dd}_%i.log </FileNamePattern>

            <!-- keep 5 days' worth of history -->
            <MaxHistory>5</MaxHistory>

            <timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
                <MaxFileSize>100MB</MaxFileSize>
            </timeBasedFileNamingAndTriggeringPolicy>

        </rollingPolicy>

    </appender>

    <appender name="stdout" class="ch.qos.logback.core.ConsoleAppender">
        <encoder>
            <pattern>%date %-5level [%logger{36}:%F.%M:%L - %thread] - %msg%n</pattern>
        </encoder>
    </appender>

    <appender name="dbAppender" class="com.tdameritrade.commons.log.ApplicationMessagesAppender" />

    <root level="INFO">
        <appender-ref ref="stdout" />
        <appender-ref ref="rollingFile" />
        <appender-ref ref="dbAppender" />
    </root>

    <logger name="org.springframework" level="WARN" />
    <logger name="org.springframework.web.servlet.DispatcherServlet" level="INFO" />
    <logger name="org.apache.jasper" level="WARN" />
    <logger name="springfox.documentation.spring" level="WARN" />
    <logger name="org.apache.tomcat.util.net" level="WARN" />
    <logger name="org.apache.coyote.http11" level="WARN" />



    <logger name="mmAchFulfillmentLogger" level="INFO" additivity="false">
        <appender-ref ref="rollingFile" />
        <appender-ref ref="stdout" />
    </logger>



</configuration>

В настоящее время мы должны создать экземпляры обоих регистраторов, а затем вызвать их в зависимости от типа сообщения.

private static final LogManager coreLogManager = new LogManager(AchFulfillmentLoggerUtil.class, "MM_ACH_FULFILLMENT");

private static final Logger mmAchFulfillmentLogger = LoggerFactory.getLogger("mmAchFulfillmentLogger");

Есть ли способ, которым мы можем объединить эти два вместе в logback.xml, чтобы мы могли создать экземпляр одного менеджера журналов в классе и затем сделать следующее.

  • Если уровень - ОШИБКА, тогда вызовите регистратор основной компании и наш файловый регистратор
  • Если уровень что-то еще, просто позвоните в наш файловый регистратор.

Я искал, но наша проблема кажется несколько уникальной, чтобы найти ответ

1 ответ

Решение

ThresholdFilter должно быть хорошо для этого:

<appender name="dbAppender" class="com.tdameritrade.commons.log.ApplicationMessagesAppender" >
  <filter class="ch.qos.logback.classic.filter.ThresholdFilter">
    <level>error</level>
  </filter>
</appender>

Затем четко прикрепите это под соответствующим логгером (-ами), а также файловым логгером.

Другие вопросы по тегам