Java使用Logback将log日志保存到指定目录文件

1.需要导入的依赖,版本可以根据需求更改。在pom.xml里添加

 <!-- log -->
        <dependency>
            <groupId>ch.qos.logback</groupId>
            <artifactId>logback-classic</artifactId>
            <version>1.2.9</version>
        </dependency>

2.在src/main/resources/目录下创建一个Logback配置文件,这里命名为logback.xml

参考代码如下:

<configuration>
    <appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">
        <encoder>
            <!-- 日志保存的时间格式 例如2024-06-14 23:59:23.076 [pool-2-thread-7] DEBUG Adjust           <pattern>%d{yyyy-MM-dd HH:mm:ss} %-5p %c{1}:%L - %m%n</pattern>-->
            <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n</pattern>
        </encoder>

        <!--临界值日志过滤级别配置 -->
        <filter class="ch.qos.logback.classic.filter.ThresholdFilter"><!-- 只打印DEBUG日志 -->
            <!-- 在日志配置级别的基础上过滤掉info级别以下的日志 WARN-->
            <level>DEBUG</level>
        </filter>
    </appender>

    <appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <!-- 指定日志文件名的时间格式,例如每天生成一个新的日志文件 例如/devdata/adjust/logs/adjust_2024-05-16.log-->
            <!--/devdata/adjust/logs/是linux下的目录,注意,windows下可以是E:/MDS/JavaWork2/logs-->            -->
            <fileNamePattern>/devdata/adjust/logs/adjust_%d{yyyy-MM-dd}.log</fileNamePattern>
            <!-- 最多保留的文件数量,当上面的文件以日期分割时,才是保存最近30天的日志文件 -->
            <maxHistory>30</maxHistory>
            <!--重启清理日志文件-->
            <cleanHistoryOnStart>true</cleanHistoryOnStart>
        </rollingPolicy>
        <encoder>
            <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n</pattern>
        </encoder>

    </appender>

    <!-- 日志级别排序为: TRACE < DEBUG < INFO < WARN < ERROR -->
    <!-- 日志输出级别 -->
    <root level="ALL">
        <appender-ref ref="CONSOLE"/>
        <appender-ref ref="FILE"/>
    </root>
</configuration>

3.最后在代码运行时调用log方法即可,下面是参考的工具类

package util;
import org.slf4j.LoggerFactory;
public class LogBackUtil {
    //打印日志
    //在Java的日志框架(如SLF4J和Logback或Log4j)中,当你使用LoggerFactory.getLogger(String name)方法时,你传递的字符串参数name通常用于标识或命名该日志记录器(Logger)。在这个特定的例子中,"Adjust"就是这个日志记录器的名称。
    //"Adjust"这个名称本身并没有特定的、固定的含义,它完全取决于你的应用程序或项目的上下文。
    public static  org.slf4j.Logger logger = LoggerFactory.getLogger("Adjust");
    //打印日志的工具方法
    public static void debug(String data){
        logger.debug(data);
    }
    public static void error(String data){
        logger.error(data);
    }
    public static void info(String data){
        logger.info(data);
    }
    public static void warn(String data){
        logger.warn(data);
    }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值