如何将特定类记录到Spring Boot中的另一个日志文件中

时间:2015-08-11 12:06:24

标签: java logging spring-boot

我在application.properties中有简单的日志设置:

logging.file = logs/debug.log
logging.level.org.hibernate.SQL = DEBUG
logging.level.org.hibernate.type = TRACE

我有一个包co.myapp.notifier。我希望此程序包的所有类都记录到logs/notifier.log。我试过了 https://stackoverflow.com/a/9652239https://stackoverflow.com/a/728351 没有运气。 在所有情况下,消息都会发送到我的debug.log

1 个答案:

答案 0 :(得分:7)

如果您需要这样做,则需要自己的logback.xml文件。

<configuration>

<!-- Normal debug log appender -->
  <appender name="FILE" class="ch.qos.logback.core.FileAppender">
    <file>debug.log</file>

    <encoder>
      <pattern>%date %level [%thread] %logger{10} [%file:%line] %msg%n</pattern>
    </encoder>
  </appender>

<appender name="virtuallab" type="ch.qos.logback.core.rolling.RollingFileAppender">
   <file value="Logs/virtuallab.log"/>
   <appendToFile value="true"/>
   <maxSizeRollBackups value="5"/>
   <maximumFileSize value="5MB"/>
   <rollingStyle value="Size"/>
   <staticLogFileName value="true"/>
   <encoder>
     <pattern>%-4relative [%thread] %-5level %logger{35} - %msg%n</pattern>
   </encoder>
</appender>

<!-- Setup the root category, add the appenders and set the default level -->
  <root level="debug">
    <appender-ref ref="FILE" />
  </root>

<!-- Specify the level specific to co.myapp.notifier -->
<logger name="co.myapp.notifier">
  <level value="ALL" />
  <appender-ref ref="virtuallab" />
</logger>

</configuration>

如果您需要控制台日志,则可能还需要添加它。 Here是文档,也请阅读此question