目录
Logback
Logback的简单使用
Logback配置文件
log4j.peoperties转化为logback.xml
Logback
Logback的性能要比log4j要好。
Logback分为三个模块:
- logback-core:其他两个模块的基础模块
- logback-classic:它是log4j的一个改良版本,同时也实现了slf4j API
- logback-access:访问模块与Servlet容器集成提供通过Http来访问日志的功能(基本不用)
Logback的简单使用
引入依赖
<dependencies>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
<version>1.7.12</version>
</dependency>
<dependency>
<groupId>ch.qos.logback</groupId>
<artifactId>logback-classic</artifactId>
<version>1.2.3</version>
</dependency>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.12</version>
</dependency>
</dependencies>
public class TestLogback {
public final static Logger logger = LoggerFactory.getLogger(TestLogback.class);
@Test
public void testLog() throws Exception {
logger.error("error");
logger.warn("wring");
logger.info("info");
logger.debug("debug");
logger.trace("trace");
}
}
Logback配置文件
logback会依次读取以下类型的配置文件
- logback.groovy
- logback-test.xml
- logback.xml
如果都不存在则会使用默认配置。
下面是xml格式的编写方式
<?xml version="1.0" encoding="UTF-8"?>
<configuration>
<!--
配置集中管理属性
我们可以直接改属性的 value 值
格式:$(name}
-->
<property name="pattern" value="[%-5level] %d{yyyy-MM-dd HH:mm:ss} %M %L [%thread] %m%n"></property>
<property name="log_dir" value="D:/logs"></property>
<!--
日志输出格式:
%-5level 日志级别
%d{yyyy-MM-dd HH:mm:ss}日期
%c类的完整名称
%M为method
%L为行号
%thread线程名称
%m或者%msg为信息
%n换行
-->
<appender name="console" class="ch.qos.logback.core.ConsoleAppender">
<!--控制输出流对象,默认为System.out黑色字体-->
<target>System.err</target>
<encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
<pattern>${pattern}</pattern>
</encoder>
</appender>
<appender name="file" class="ch.qos.logback.core.FileAppender">
<!--指定保存路径-->
<file>${log_dir}/logback.log</file>
<encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
<pattern>${pattern}</pattern>
</encoder>
</appender>
<!--html格式日志文件输出appender-->
<appender name="htmlFile" class="ch.qos.logback.core.FileAppender">
<!--指定保存路径-->
<file>${log_dir}/logback.html</file>
<encoder class="ch.qos.logback.core.encoder.LayoutWrappingEncoder">
<layout class="ch.qos.logback.classic.html.HTMLLayout">
<pattern>%-5level %d{yyyy-MM-dd HH:mm:ss} %M %L %thread %m%n</pattern>
</layout>
</encoder>
</appender>
<appender name="rollFile" class="ch.qos.logback.core.rolling.RollingFileAppender">
<file>${log_dir}/roll_logback.log</file>
<encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
<pattern>${pattern}</pattern>
</encoder>
<!--指定拆分规则-->
<rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
<!--按时间格式拆分-->
<fileNamePattern>${log_dir}/rolling.%d{yyyy-MM-dd} %i.log</fileNamePattern>
<!--按文件大小拆分-->
<maxFileSize>1MB</maxFileSize>
</rollingPolicy>
<!--日志过滤规则-->
<filter class="ch.qos.logback.classic.filter.LevelFilter">
<!--只输出error以上级别的日志-->
<level>ERROR</level>
<onMatch>ACCEPT</onMatch>
<onMismatch>DENY</onMismatch>
</filter>
</appender>
<!--异步记录日志,提升性能-->
<appender name="async" class="ch.qos.logback.classic.AsyncAppender">
<appender-ref ref="rollFile"></appender-ref>
</appender>
<!--root Logger配置-->
<root level="ALL">
<appender-ref ref="console"></appender-ref>
<appender-ref ref="file"></appender-ref>
<appender-ref ref="htmlFile"></appender-ref>
</root>
</configuration>
使用配置文件后输出为下图所示。
log4j.peoperties转化为logback.xml
官方转换地址https://logback.qos.ch/translator/services/xml2Canon.html
转换后的结果