unifirst的技术博客

不断学习 不断进步

Logback配置

Dependencies

Slf4j、log4j、logback关系介绍中所说,sif4j+logback日志体系,其dependencies:

  • slf4j-api (slf4j接口)
  • logback-classic (logback服务于slf4j的"驱动")
  • logback-core (logback日志实现)

logback配置

logback.xml示例如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE configuration>
<configuration>
  <appender name="console" class="ch.qos.logback.core.ConsoleAppender">
      <encoder>
          <pattern>%d %p [%t] [%X{xxx}] - %m%n</pattern>
      </encoder>
  </appender>
  <logger name="console_logger" additivity="false">
      <appender-ref ref="console" />
  </logger>
  <logger name="com.xxx.xxx" level="INFO" additivity="false">
      <appender-ref ref="console" />
  </logger>
  <root level="info">
      <appender-ref ref="console" />
      <appender-ref ref="info" />
  </root>
</configuration>

appender

appender是否则写日志的组件,定义日志的输出位置、格式等。包括以下几种:

  • ConsoleAppender:把日志添加到控制台
  • FileAppender:把日志添加到文件
  • RollingFileAppender:滚动记录文件,先将日志记录到指定文件,当符合某个条件时,将日志记录到其他文件
  • SMTPAppender:把日志发邮件
  • 其它还有SocketAppender、DBAppender、SyslogAppender、SiftingAppender等

logger

logger用来设置某一个包或者具体的某一个类的日志打印级别、以及指定appender。其有name、level、additivity三个属性

  • name:name可以为java中的包或类,表示对该包或类采用该种日志打印级别。也可以为自定义的名字,如“console_logger”, 在使用LoggerFactory.getLogger(“console_logger”)打印log时,即采用该种打印级别,但这种方式打出的日志会以“console_logger”代替具体类名,不便于定位日志位置。
  • level:日志级别,INFO、ERROR等,未设置时默认采用上级日志级别
  • additivity:是否向上级传递,若向上级传递,可能会导致打印重复日志。注意,若向上级传递,会连同日志级别一起向上级传递。

root

logger层级的根。只有level属性。按照appender-ref中定义的方式打印。

所有的日志,只要不在各logger范围内,或者由logger向上级root传递,都会按root级别处理。此时若日志级别大于等于root的level,都会按root设置的打印方式输出。