logback和slf4j简介
logback是java的日志开源组件,其性能要优于log4j,logback主要模块有三个
logback-core:核心代码模块。
logback-classic:log4j的一个改良版本,同时实现了slf4j的接口,这使得切换其他日志组件变得很容易。
logback-access:访问模块与Servlet容器集成提供通过Http来访问日志的功能。
使用logback
首先在maven项目中引入依赖
<!--这个依赖包含了 logback-core 和 slf4j-api的依赖-->
<dependency>
<groupId>ch.qos.logback</groupId>
<artifactId>logback-classic</artifactId>
<version>1.2.3</version>
</dependency>
接下来就可以直接在代码中使用slf4j的接口获取Logger输出日志
//这是slf4j的接口,由于我们引入了logback-classic依赖,所以底层实现是logback
private static final Logger LOGGER = LoggerFactory.getLogger(Test.class);
public static void main(String[] args) throws InterruptedException{
LOGGER.info("hello world");
}
配置logback
配置文件加载顺序
logback在启动的时候,会按照如下顺序加载配置文件,上面的顺序表示优先级,使用java -D配置的优先级最高,只要获取到配置后就不会再执行下面的流程
1.如果java程序启动时指定了logback.configurationFile属性,就用该属性指定的配置文件。如java -Dlogback.configurationFile=/path/to/mylogback.xml Test,这样执行Test类的时候就会加载/path/to/mylogback.xml配置。
2.在classpath中查找logback.groovy文件。
3.在classpath中查找logback-test.xml文件。
4.在classpath中查找logback.xml文件。
5.如果是 jdk6+,那么会调用ServiceLoader 查找 com.qos.logback.classic.spi.Configurator接口的第一个实现类。
6.自动使用ch.qos.logback.classic.BasicConfigurator,在控制台输出日志。
slf4j日志输出级别
slf4j日志输出级别从小到大依序是trace、debug、info、warn、error。
logback.xml文件配置示例
<?xml version="1.0" encoding="UTF-8"?>
<configuration debug="false">
<!--定义日志文件的存储地址 勿在 LogBack 的配置中使用相对路径-->
<property name="LOG_HOME" value="/home"/><!-- 控制台输出 -->
<appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
<encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
<!--格式化输出:%d表示日期,%thread表示线程名,%-5level:级别从左显示5个字符宽度%msg:日志消息,%n是换行符-->
<pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n</pattern>
</encoder>
</appender>
<!-- 按照每天生成日志文件 -->
<appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<!--日志文件输出的文件名--> <FileNamePattern>${LOG_HOME}/TestWeb.log.%d{yyyy-MM-dd}.log</FileNamePattern>
<!--日志文件保留天数-->
<MaxHistory>30</MaxHistory>
</rollingPolicy>
<encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
<!--格式化输出:%d表示日期,%thread表示线程名,%-5level:级别从左显示5个字符宽度%msg:日志消息,%n是换行符-->
<pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n</pattern>
</encoder>
<!--日志文件最大的大小-->
<triggeringPolicy class="ch.qos.logback.core.rolling.SizeBasedTriggeringPolicy">
<MaxFileSize>10MB</MaxFileSize>
</triggeringPolicy>
</appender>
<!-- 日志输出级别 -->
<root level="INFO">
<appender-ref ref="STDOUT"/>
</root>
</configuration>
configuration子节点介绍
1.contextName节点
设置日志上下文名称,后面输出格式中可以通过定义 %contextName 来打印日志上下文名称。
2.property节点
用来设置相关变量,通过key-value的方式配置,然后在后面的配置文件中通过 ${key}来访问。
3.appender 节点
日志输出组件,主要负责日志的输出以及格式化日志。
ConsoleAppender:向控制台输出日志内容的组件,只要定义好encoder节点就可以使用。
FileAppender:向文件输出日志内容的组件,用法也很简单,不过由于没有日志滚动策略,一般很少使用
RollingFileAppender:向文件输出日志内容的组件,同时可以配置日志文件滚动策略,在日志达到一定条件后生成一个新的日志文件。
appender节点中有一个子节点filter,配置具体的过滤器,这样用这个appender输出日志的时候都会经过这个过滤器,日志级别低于过滤器中配置级别的都不会输出来。
slf4j
slf4j只是一套标准,简单来说就是定义了一系列接口,它并不提供任何的具体实现。所以,我们使用这套接口进行开发,可以任意的切换底层的实现框架。
例如想要将项目中的log4j换成logback,由于项目代码是面向slf4j接口的,因此只要将log4j的依赖换成logback就可以了。
上一篇: ubuntu samba 共享文件夹
下一篇: 修改浏览器默认滚动条样式