java日志框架4-Logback

一 概述

Logback是由log4j创始人设计的另一个开源日志组件,性能比log4j要好。

二 入门使用

使用过SLF4J日志门面搭建日志系统,,所以在代码是没有区别,主要是通过修改配置
文件和pom.xml依赖。

  • 依赖
	<dependency>
        <groupId>ch.qos.logback</groupId>
        <artifactId>logback-classic</artifactId>
        <version>1.2.3</version>
    </dependency>
    <dependency>
        <groupId>org.slf4j</groupId>
        <artifactId>slf4j-api</artifactId>
        <version>1.7.30</version>
    </dependency>
  • 代码
public class LogBackTest {
    public final static Logger logger = LoggerFactory.getLogger(LogBackTest.class);
    @Test
    public void test01(){
        logger.error("error test01");
        logger.warn("warn test01");
        logger.info("info test01");
        logger.debug("debug test01");
        logger.trace("trace test01");
    }
}
  • 输出
15:54:39.809 [main] ERROR com.salulu.logger.test.LogBackTest - error test01
15:54:39.814 [main] WARN com.salulu.logger.test.LogBackTest - warn test01
15:54:39.814 [main] INFO com.salulu.logger.test.LogBackTest - info test01
15:54:39.814 [main] DEBUG com.salulu.logger.test.LogBackTest - debug test01

可以看出,在没有自定义配置文件的基础下,默认是输出debug级别的日志。

三 配置文件

会依次查找logback.groovy、logback-test.xml、logback.xml配置文件,如果均不存在会采用默认配置。

1 日志输出格式

<property name="pattern" value="%d{yyyy-MM-dd HH:mm:ss.SSS} %c [%thread] %-5level %msg%n"/>

%d 表示日期
%thread 表示线程名
%-5level 级别从左显示5个字符宽度
%msg 日志消息
%n 是换行符
%M 表示method
%L 表示行号

2 Appender

设置日志信息的去向,常用的有以下几个:
控制台:ch.qos.logback.core.ConsoleAppender
文件:ch.qos.logback.core.FileAppender
切分文件:ch.qos.logback.core.rolling.RollingFileAppender

  • 控制台
	<appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
		<!-- 对日志进行格式化 -->
		<encoder>
			<pattern>%d{yyyy-MM-dd HH:mm:ss} [%thread] %-5level %logger{36} -%msg%n</pattern>
		</encoder>
	</appender>
  • 文件
	<!--定义日志文件保存路径属性-->
    <property name="log_dir" value="/xxx/xxx/xxx"></property>
    
	<!--日志文件输出的 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文件:

<!--html 格式日志文件输出 appender-->
    <appender name="htmlFile" class="ch.qos.logback.core.FileAppender">
        <!--日志文件保存路径-->
        <file>${log_dir}/logback.html</file>
        <!--html 消息格式配置-->
        <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.SSS}%c%M%L%thread%m</pattern>
            </layout>
        </encoder>
    </appender>
  • 切分文件
    <!--日志拆分和归档压缩的 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}.log%i.gz</fileNamePattern>
            <!--按照文件大小拆分-->
            <maxFileSize>1MB</maxFileSize>
        </rollingPolicy>
        <!--日志级别过滤器-->
        <filter class="ch.qos.logback.classic.filter.LevelFilter">
            <!--日志过滤规则-->
            <!--设置过滤级别  例如:将过滤器的日志级别配置为INFO,所有INFO级别的日志交给appender处理,非INFO级别的日志,被过滤掉。 -->
            <level>ERROR</level>
            <!--用于配置符合过滤条件的操作-->
            <onMatch>ACCEPT</onMatch>
            <!--用于配置不符合过滤条件的操作-->
            <onMismatch>DENY</onMismatch>
        </filter>
    </appender>

3 输出配置

  • root配置
	<!--root logger 配置-->
    <root level="ALL">
    	<!-- 配置了两个appender 分别输出到控制台和html文件 -->
        <appender-ref ref="console"/>
        <appender-ref ref="htmlFile"/>
    </root>
  • 自定义配置
    <!--自定义 looger 对象 对com.salulu包下的产生的日志做配置,只要info级别以上的,并且只输出到控制台
        additivity="false" 自定义 logger 对象是否继承 rootLogger
     -->
    <logger name="com.salulu" level="info" additivity="false">
        <appender-ref ref="console"/>
    </logger>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值