3

在我的 logback 配置文件中,我有以下可用的附加程序:

<appender name="thread_SIFT" class="ch.qos.logback.classic.sift.SiftingAppender">
    <discriminator class="[...]"/>
    <sift>
        <appender name="FILE-${threadName}" class="ch.qos.logback.core.FileAppender">
            <file>[...]/${bySecond}/${threadName}.log</file>
            <layout class="ch.qos.logback.classic.PatternLayout">
               <pattern>%date %level %logger{0} - %msg%n</pattern>
            </layout>
        </appender>
    </sift>
</appender>

该文件已正确创建。如果我用 RollingFileAppender 替换 FileAppender,则不会创建任何内容。为什么?我怎样才能让它工作>

threadName 由鉴别器设置。

4

4 回答 4

4

OnConsoleStatusListener你的朋友。只需添加

<configuration>
  <statusListener class="ch.qos.logback.core.status.OnConsoleStatusListener" />
  .. remainder of your config file
</configuration>

在配置文件的开头查看由SiftingAppender.

于 2011-01-17T16:36:32.263 回答
2

似乎财产${bySecond}或任何其他人在sift > appender标签内丢失。

ERROR in ch.qos.logback.core.joran.spi.Interpreter@23:97 - no applicable
action for [property], current pattern is [[configuration][appender][property]]
[...]/bySecond_IS_UNDEFINED/main.log
于 2012-02-10T19:24:55.480 回答
0

包名有错误。似乎标签筛选下的错误被默默地忽略了。为了进行测试,我需要将 appender 复制到 sift 标签之外,确保没有错误并将其复制回来。

于 2011-01-14T20:26:07.303 回答
-1

作为对我评论的补充,您可以验证是否在您的 sift appender 中使用此 appender 正确创建了文件(取自关于 RollingFileAppender 配置的 Logback 教程)。

  <appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
    <file>test.log</file>

    <rollingPolicy class="ch.qos.logback.core.rolling.FixedWindowRollingPolicy">
      <fileNamePattern>tests.%i.log.zip</fileNamePattern>
      <minIndex>1</minIndex>
      <maxIndex>3</maxIndex>
    </rollingPolicy>

    <triggeringPolicy class="ch.qos.logback.core.rolling.SizeBasedTriggeringPolicy">
      <maxFileSize>5MB</maxFileSize>
    </triggeringPolicy>

    <encoder>
      <pattern>%-4relative [%thread] %-5level %logger{35} - %msg%n</pattern>
    </encoder>
  </appender>
于 2011-01-14T19:43:33.927 回答