与log4j相比,logback具有一些优势,如更好的性能、更少的内存使用、自动重加载配置文件以及过滤功能等。
下面简要介绍下logback的使用:
1. 在pom.xml文件中添加依赖:
Xml代码
- <properties>
- <logback.version>1.0.11</logback.version>
- <slf4j.api.version>1.7.5</slf4j.api.version>
- </properties>
- <dependencies>
- <dependency>
- <groupId>org.slf4j</groupId>
- <artifactId>slf4j-api</artifactId>
- <version>${slf4j.api.version}</version>
- </dependency>
- <dependency>
- <groupId>ch.qos.logback</groupId>
- <artifactId>logback-classic</artifactId>
- <version>${logback.version}</version>
- </dependency>
- <dependency>
- <groupId>ch.qos.logback</groupId>
- <artifactId>logback-core</artifactId>
- <version>${logback.version}</version>
- </dependency>
- </dependencies>
2. 在类路径下新建logback.xml或logback-test.xml(优先级高)文件:
Xml代码
- <?xml version="1.0" encoding="UTF-8"?>
- <configuration>
- <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
- <!-- encoder的默认实现类是ch.qos.logback.classic.encoder.PatternLayoutEncoder -->
- <encoder>
- <pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{5} - %msg%n</pattern>
- </encoder>
- </appender>
- <!-- name值可以是包名或具体的类名:该包(包括子包)下的类或该类将采用此logger -->
- <logger name="com.john.logging.b" level="INFO">
- <appender-ref ref="STDOUT" />
- </logger>
- <!-- root的默认level是DEBUG -->
- <root level="DEBUG">
- <appender-ref ref="STDOUT" />
- </root>
- </configuration>
3. 测试类:
Java代码
- package com.john.logging.a;
- public class Reconciliation {
- private static final Logger log = LoggerFactory.getLogger(Reconciliation.class);
- public void reconciliate() {
- String name = "conciliate";
- log.info("Hello from reconciliate");
- log.debug("My name is {}", name);
- }
- }
Java代码
- package com.john.logging.b;
- public class Corruption {
- // logger名称为类的全限定名
- private static final Logger log = LoggerFactory.getLogger(Corruption.class);
- public void corrupt() {
- String name = "allegation";
- log.info("Hello from corrupt.");
- log.debug("My name is {}", name);
- }
- }
输出:
11:50:16.266 [main] INFO c.j.l.a.Reconciliation - Hello from reconciliate
11:50:16.270 [main] DEBUG c.j.l.a.Reconciliation - My name is conciliate
11:50:16.271 [main] INFO c.j.l.b.Corruption - Hello from corrupt.
11:50:16.271 [main] INFO c.j.l.b.Corruption - Hello from corrupt.
所有logger的始祖是ROOT,默认会继承ROOT的配置,因此Corruption中的日志会打印两次。
解决:logger的additivity属性设置为false
Xml代码
- <logger name="com.john.logging.b" level="INFO" additivity="false">
本文介绍了如何在Java项目中使用Logback进行日志记录。包括配置Maven依赖、创建logback.xml配置文件以及在代码中使用日志记录。通过示例展示了不同级别的日志输出及如何避免重复记录。

2823

被折叠的 条评论
为什么被折叠?



