java 集成LogBack

LogBack是由log4j创始人设计的开源日志组件,分为logback-core、logback-classic和logback-access三个模块。logback-classic是log4j的改良版,并实现SLF4J API。本文介绍了如何在Java项目中导入LogBack依赖,配置文件的位置、详解及使用案例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Logback是由log4j创始人设计的又一个开源日志组件。

                logback当前分成三个模块:logback-core,logback- classic和logback-access。

                logback-core是其它两个模块的基础模块。

                logback-classic是log4j的一个 改良版本。此外logback-classic完整实现SLF4J API使你可以很方便地更换成其它日志系统如log4j或JDK14 Logging。

                logback-access访问模块与Servlet容器集成提供通过Http来访问日志的功能。

导入依赖

    <!-- LogBack -->
    <dependency>
        <groupId>org.slf4j</groupId>
        <artifactId>slf4j-api</artifactId>
        <version>1.7.7</version>
    </dependency>
    <dependency>
        <groupId>ch.qos.logback</groupId>
        <artifactId>logback-core</artifactId>
        <version>1.1.3</version>
    </dependency>
    <dependency>
        <groupId>ch.qos.logback</groupId>
        <artifactId>logback-access</artifactId>
        <version>1.1.3</version>
    </dependency>
    <dependency>
        <groupId>ch.qos.logback</groupId>
        <artifactId>logback-classic</artifactId>
        <version>1.1.3</version>
    </dependency>
    <!-- LogBack -->   

配置文件位置

 logback的配置文件logback.xml文件默认放在/src/main/resource/文件夹下,本文放在/config/下

配置文件详解

<?xml version="1.0" encoding="UTF-8" ?>
<configuration>
   
    <!--定义日志文件的存储地址 勿在 LogBack 的配置中使用相对路径-->  
    <property name="LOG_HOME" value="./log" />  
    
    <!-- 日志前缀名称 -->
    <property name="LOG_NAME" value="spider" />  
   
    <!-- 控制台输出 -->   
    <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
        <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder"> 
             <!--格式化输出:%d表示日期,%thread表示线程名,%-5level:级别从左显示5个字符宽度,%logger{50}输出日志的类 50代表包名加类名的总长度限制, %msg:日志消息,%n是换行符--> 
            <pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n</pattern>   
        </encoder> 
    </appender>
   
    <!-- 按照每天生成日志文件 -->   
    <appender name="ROLLING_FILE"  class="ch.qos.logback.core.rolling.RollingFileAppender">   
       
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <!--日志文件输出的文件名-->
            <FileNamePattern>${LOG_HOME}/${LOG_NAME}-%d{yyyy-MM-dd}.log</FileNamePattern> 
            <!--日志文件保留天数-->
            <MaxHistory>30</MaxHistory>
        </rollingPolicy>   
       
        <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder"> 
            <!--格式化输出:%d表示日期,%thread表示线程名,%-5level:级别从左显示5个字符宽度,%logger{50}输出日志的类 50代表包名加类名的总长度限制, %msg:日志消息,%n是换行符--> 
            <pattern>%d{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="DEBUG">
        <appender-ref ref="STDOUT" />
        <appender-ref ref="ROLLING_FILE" />
    </root> 
    
</configuration>

使用案例 

package clo.info.client;

import java.io.IOException;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import ch.qos.logback.core.joran.spi.JoranException;
import clo.info.util.LogBackConfigurator;

public class LogBackTest {
	private static Logger logger = LoggerFactory.getLogger(LogBackTest.class);

	public static void main(String[] args) {
		initLogger();
		logger.debug("输出debug级别的日志.....");  
        logger.info("输出info级别的日志.....");  
        logger.error("输出error级别的日志.....");  
}
	
	private static void initLogger() {
		try {
			LogBackConfigurator.load("config/logback.xml");
		} catch (IOException e) {
			e.printStackTrace();
		} catch (JoranException e) {
			e.printStackTrace();
		}
	}
}


如果是java web工程需要在web.xml中添加

<context-param>  
         <param-name>logbackConfigLocation</param-name>  
         <param-value>config/logback.xml</param-value>  
</context-param>  
<listener>  
         <listener-class>ch.qos.logback.ext.spring.web.LogbackConfigListener</listener-class>  
</listener>  


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值