Java日志系统之Logback

编程入门 行业动态 更新时间:2024-10-17 02:59:20

Java日志<a href=https://www.elefans.com/category/jswz/34/1770742.html style=系统之Logback"/>

Java日志系统之Logback

目录

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

官方转换地址.html

转换后的结果

更多推荐

Java日志系统之Logback

本文发布于:2023-12-05 21:31:47,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/1665366.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:系统   日志   Java   Logback

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!