@Slf4j+logback.xml如何配置不同类或方法的日志打印到不同的文件中
时间: 2024-02-23 15:58:40 浏览: 155
要实现不同类或方法的日志打印到不同的文件中,可以按照以下步骤:
1. 在logback.xml文件中定义多个appender,每个appender代表一个日志文件。
2. 在每个appender中设置不同的文件名和日志级别。
3. 在logger中指定要输出日志的类或方法的名称,以及输出到哪个appender。
具体的配置方式如下:
```xml
<?xml version="1.0" encoding="UTF-8"?>
<configuration>
<!-- 定义输出到控制台的appender -->
<appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">
<encoder>
<pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n</pattern>
</encoder>
</appender>
<!-- 定义输出到文件1的appender -->
<appender name="FILE1" class="ch.qos.logback.core.rolling.RollingFileAppender">
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<fileNamePattern>/logs/file1-%d{yyyy-MM-dd}.log</fileNamePattern>
<maxHistory>30</maxHistory>
</rollingPolicy>
<encoder>
<pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n</pattern>
</encoder>
</appender>
<!-- 定义输出到文件2的appender -->
<appender name="FILE2" class="ch.qos.logback.core.rolling.RollingFileAppender">
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<fileNamePattern>/logs/file2-%d{yyyy-MM-dd}.log</fileNamePattern>
<maxHistory>30</maxHistory>
</rollingPolicy>
<encoder>
<pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n</pattern>
</encoder>
</appender>
<!-- 定义logger,输出到控制台和文件1 -->
<logger name="com.example.package1" level="DEBUG">
<appender-ref ref="CONSOLE"/>
<appender-ref ref="FILE1"/>
</logger>
<!-- 定义logger,输出到文件2 -->
<logger name="com.example.package2" level="INFO">
<appender-ref ref="FILE2"/>
</logger>
</configuration>
```
在这个例子中,我们定义了两个appender:CONSOLE和FILE1、FILE2。CONSOLE输出到控制台,FILE1和FILE2分别输出到文件1和文件2。
然后我们分别定义了两个logger,com.example.package1和com.example.package2,分别输出到CONSOLE和FILE1,以及FILE2。
这样,如果我们想要把com.example.package1的日志输出到文件1,com.example.package2的日志输出到文件2,就可以按照以上方式进行配置。
阅读全文