Spring Boot Logging 配置
发布时间:2025-05-20 21:50:57 发布人:远客网络
一、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的使用,输出结果包含类的相对路径,便于开发人员定位信息。