您当前的位置:首页 > 互联网教程

Spring Boot Logging 配置

发布时间:2025-05-20 21:50:57    发布人:远客网络

Spring Boot Logging 配置

一、Spring Boot Logging 配置

Spring Boot能够使用Logback, Log4J2, java util logging作为日志记录工具。Spring Boot默认使用Logback作为日志记录工具。日志默认输出到控制台但也能输出到文件中。我们通过spring-boot-starter-logging加入Logback依赖,其实只要我们加入任意的Spring Boot starter都会默认引入spring-boot-starter-logging,因此我们不需要分开加入他们。

logging.level.*:作为package(包)的前缀来设置日志级别。

logging.file:配置日志输出的文件名,也可以配置文件名的绝对路径。

logging.path:配置日志的路径。如果没有配置 logging.file,Spring Boot将默认使用spring.log作为文件名。

logging.pattern.console:定义console中logging的样式。

logging.pattern.file:定义文件中日志的样式。

logging.pattern.level:定义渲染不同级别日志的格式。默认是%5p.

logging.exception-conversion-word:.定义当日志发生异常时的转换字

下面将讨论在 application.properties, application.ym, Logback XML中配置Logback以及在Spirng Boot应用中使用Log4J2.

logging.level设置日志级别。我们可以使用TARCE, DEBUG, INFO, WARN, ERROR, FATAL, OFF。可以使用root级别和package级别来控制日志的输入级别。创建一个具有以下依赖关系的应用程序。

使用 src\main\resources\application.properties配置日志级别

使用 src\main\resources\application.yml

Spring Boot默认把日志输入到console,如果我们要把日志输入到文件中,需要配置logging.file或者logging.path属性性。logging.file属性用来定义文件名。他不仅仅可以配置文件名,也可以路径+文件名。

在这种情况下mylogfile.log将在根目录中创建。我们也可以为为mylogfile.log分配一个路径,如concretepage/mylogfile.log。这种情况下我们将在相对根目录下创建concretepage/mylogfile.log。我们也可以为日志文件配置绝对路径。

配置logging.path或者logging.path属性将日志输出到文件夹中。logging.path属性用来定义日志文件路径

在 application.properties中配置logging.path属性

将会相对根路径下创建concretepage/logs/spring.log,也可以配置绝对路径

通过设置logging.patter.console属性我们能改变输出到console的日志样式。日志样式包括时间,日志级别,线程名,日志名以及消息。我们可以按我们的喜好改变日志样式。

改变文件中的日志样式我们需要设置logging.pattern.file属性。首先通过logging.file或logging.path属性,把日志记录到文件中。

通过logging.path属性将在根目录下创建concretepage/logs并默认使用spring.log作为文件名。logging.pattern.console是设置console的日志样式

Sping Boot默认输出ERROR, WARN, INFO级别的日志。我们可以通过命令行使能DEBUG,TRACE级别的日志输出,效果是跟配置文件一样的。想象我们有一个名为my-app.jar的可执行的JAR包我们可以在启动应用是使能DEBUG级别日志输出。

在application.properties中配置

创建一个SLF4J的例子,首先获得org.slf4j.Logger的实例。

在application.properties配置包com.concretepage日志记录级别

Sping Boot中默认使用logback,我们可以在application.properties或者application.yml中设置日志级别。如果想使用XML配置Logback,我们需要在类路径下创建logback-spring.xml文件

src\main\resources\logback-spring.xml

我们使用任何的starter,默认加入Logback依赖spring-boot-starter-logging。为了使用Log4J2,我们首先要去除spring-boot-starter-logging并且引入spring-boot-starter-log4j2依赖

现在我们可以在类路径下创建并配置log4j2-spring.xml

原文:

二、Java日志的使用方法

1、Java日志可以通过使用java.util.logging包中的Logger类来实现.

2、首先,需要获取一个Logger实例,可以使用Logger.getLogger()方法来获取.例如:

3、Logger logger= Logger.getLogger(MyClass.class.getName());

4、使用logger实例记录日志. Logger类提供了多个重载的log()方法来记录不同级别的日志.例如:

5、logger.info("This is an info message.");

6、logger.warning("This is a warning message.");

7、logger.severe("This is a severe message.");

8、可以使用logger.setLevel()方法来设置日志记录级别,只有大于等于该级别的日志才会被记录.

9、可以使用logger.addHandler()方法来添加日志处理器(Handler),来将日志输出到不同的地方,如控制台、文件、网络等.

10、使用logger.log()可以记录不同级别的日志,可以根据需要记录不同级别的日志

11、可以使用logger.setUseParentHandlers(false)取消继承父级日志处理器,只使用自己的处理器

三、java常见log日志的使用方法详细解析

Java开发中,日志记录是调试错误和获取关键信息的重要工具,常见的日志框架包括原生的java.util.Logger、log4j和Slf4j等。这些框架支持不同级别的日志输出,如OFF、FATAL、ERROR、WARN、INFO、DEBUG、TRACE和ALL,级别越高,信息越详细。

原生Logger主要通过import java.util.logging.Logger;引入,其关键方法如日志记录和级别控制。例如,设置日志级别为ALL会输出severe、warning和info级别的信息。通过logger.setLevel(Level.ALL);实现定制输出级别。

示例代码展示,低于info级别的信息通常不会在终端显示,但可通过调整级别控制输出。

log4j框架在XML配置文件中引入,代码示例如下。它的配置选项多样,具体操作可根据文档进行调整,如Log4j2进阶使用(Pattern Layout详细设置)提供了详细说明。

Slf4j是目前主流的日志框架,支持参数占位符。每个类通常在开头引入相关依赖并使用LoggerFactory.getLogger创建日志对象。若未正确引入或引入错误,可能会遇到如SLF4J: Failed to load class...的问题,解决方案包括检查并正确引入slf4j和相关实现类。

示例代码展示了Slf4j的使用,输出结果包含类的相对路径,便于开发人员定位信息。