目录
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);@Testpublic 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
转换后的结果
需要注意的是,log4j的日志格式部分符号表示含义与logback不太一样,使用时需要进行检查后才能使用