logback使用

logback使用

1
2
3
4
5
<dependency>
<groupId>ch.qos.logback</groupId>
<artifactId>logback-classic</artifactId>
<version>1.2.3</version>
</dependency>

pom依赖logback,代码中使用slf4j

1
2
3
4
5
private org.slf4j.Logger logger = org.slf4j.LoggerFactory.getLogger(getClass());

//打印日志时使用占位符(禁止手工拼接字符串)
logger.info("file:【{}】", file.getAbsolutePath());
logger.debug("file:【{}】", file.getAbsolutePath());

classpath:logback.xml(示例:在控制台输出日志)

1
2
3
4
5
6
7
8
9
10
11
<?xml version="1.0" encoding="UTF-8"?>
<configuration>
<appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
<encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
<pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} %level [%thread] %class:%line - %msg%n</pattern>
</encoder>
</appender>
<root level="DEBUG">
<appender-ref ref="STDOUT"/>
</root>
</configuration>

logback语法

log4j.properties转logback.xml

appender配置

appender-pattern格式

格式化输出:

  • %d{yyyy-MM-dd HH:mm:ss.SSS}: 表示日期{格式化},
  • %thread: 表示线程名,
  • %-5level:日志级别从左显示5个字符宽度
  • %msg:日志消息(也可以写成%m)
  • %n:是换行符
  • %class: 类名
  • %line: 行号(也可以写成%L)

高级用法

logback-elasticsearch-appender

https://github.com/internetitem/logback-elasticsearch-appender

logback+logstash+elasticsearch

https://www.cnblogs.com/zhujiqian/p/11593671.html