Spring 我可以使用Logback.xml与两个记录器通话吗

Spring 我可以使用Logback.xml与两个记录器通话吗,spring,logback,spring-logback,Spring,Logback,Spring Logback,所以我们有一个比较独特的情况,我们有一个公司记录器,它被LoggerFactory.getLogger和类名实例化,然后被传递一个日志号,throwable exception和消息。这将转到公司管理控制台以监视日志 作为一个团队,我们目前正在使用logback.xml将任何和所有日志消息写入一个文件,以便获得额外的信息。这是我们的logback.xml <?xml version="1.0" encoding="UTF-8"?> <configuration debu

所以我们有一个比较独特的情况,我们有一个公司记录器,它被LoggerFactory.getLogger和类名实例化,然后被传递一个日志号,throwable exception和消息。这将转到公司管理控制台以监视日志

作为一个团队,我们目前正在使用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>
我们是否可以在logback.xml中将这两种方法结合在一起,以便在一个类中实例化一个日志管理器,然后执行以下操作

  • 如果级别为错误,请致电核心公司记录器和我们的文件记录器
  • 如果级别是其他级别,请调用我们的文件记录器

我一直在搜索,但我们的问题似乎有点独特,可以找到答案A
ThresholdFilter
应该可以:

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

错误

然后将其清楚地连接到相应的记录器和文件记录器下。

使用logback。使用一个专门的附加器,它可以将数据写入您想要的内容。这样,您可以在代码中使用单个记录器,并在后台配置所需内容。@M.Deinum ok。我可以将运行时信息传递给自定义appender吗?类似于记录错误时引发的日志号或异常?异常已经是SLF4J中记录API的一部分(假设您将其用作API。您可以从SLF4J将所有其他内容放入MDC中。根据您需要记录的内容/方式,您可能可以使用一个现有的附件与您的监控对话(如果是JMX或类似的东西).@M.Deinum Ok,那么在我的自定义appender中,我可以读取MDC中的内容。异常在eventObject中?
<appender name="dbAppender" class="com.tdameritrade.commons.log.ApplicationMessagesAppender" >
  <filter class="ch.qos.logback.classic.filter.ThresholdFilter">
    <level>error</level>
  </filter>
</appender>