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);
}
}