当前位置: 首页 > news >正文

杭州服装论坛网站建设成都网站设计精选柚v米科技

杭州服装论坛网站建设,成都网站设计精选柚v米科技,网站建设主题的确定,公司网站建设费用怎么记账第3章 Spring Boot 的系统配置 3.1 Spring Boot 系统配置文件 3.2 Spring Boot 自定义配置项 3.3 Spring Boot 其他配置 3.4 Spring Boot 日志配置 3.5 实战:Spring Boot 实现系统多环境配置 3.4 Spring Boot 日志配置 日志对于系统监控、故障定位非常重要&#xf…

第3章 Spring Boot 的系统配置

3.1 Spring Boot 系统配置文件
3.2 Spring Boot 自定义配置项
3.3 Spring Boot 其他配置
3.4 Spring Boot 日志配置
3.5 实战:Spring Boot 实现系统多环境配置

3.4 Spring Boot 日志配置

日志对于系统监控、故障定位非常重要,比如当生产系统发生问题时,完整清晰的日志记录有助于快速定位问题。接下来介绍 Spring Boot 对日志的支持。

3.4.1 Spring Boot 日志简介

Spring Boot 自带 spring-boot-starter-logging 库实现系统日志功能,spring-boot-starter-logging 组件默认使用 LogBack 日志记录工具。系统运行日志默认输出到控制台,也能通过配置输出到文件中。

下面通过示例来演示 Spring Boot 项目配置日志的功能。

修改 pom.xml 文件,添加spring-boot-starter-logging依赖。

pom.xml

        <!--spring boot 日志(spring-boot-starter-web 包含 spring-boot-starter,而spring-boot-starter 包含 spring-boot-starter-logging依赖包,所以引入spring-boot-starter-web之后可以不需要再引入spring-boot-starter-logging)--><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-logging</artifactId></dependency>

启动项目,查看控制台的日志输出情况,如图所示。

SpringBoot控制台启动日志(默认日志格式).png

备注:

如果项目中有引入 spring-boot-starter-web依赖包 或 spring-boot-starter依赖包,则可以不用引入spring-boot-starter-logging依赖包。

原因:这是因为spring-boot-starter-web 包含 spring-boot-starter,而spring-boot-starter 包含 spring-boot-starter-logging依赖包,所以引入spring-boot-starter-web之后可以不需要再引入spring-boot-starter-logging.

3.4.2 配置日志输出格式

在 Spring Boot 项目中配置日志功能之后,如何定制自己的日志格式、自定义记录的信息呢?

Spring Boot 提供了 logging.pattern.consolelogging.pattern.file 配置项来定制日志输出格式,只需在 application.properties 文件中添加 logging.pattern.consolelogging.pattern.file 的配置项即可:

# 3.4.2 配置日志输出格式
logging.pattern.console=%d{yyyy-MM-dd-HH:mm:ss} [%thread] %-5level %logger- %msg%n
logging.pattern.file=%d{yyyy-MM-dd-HH:mm:ss} [%thread] %-5level %logger- %msg%n

上述配置的示例中,对应符号的含义如下:

  • %d{yyyy-MM-dd-HH:mm:ss.SSS}:日志输出时间。
  • %thread:输出日志的进程名,这在 Web 应用以及异步任务处理中很有用。
  • %-5level:日志级别,使用5个字符靠左对齐。
  • %logger:日志输出者的名称。
  • %msg:日志消息。
  • %n:平台的换行符。

修改完配置项后重启项目,查看控制台的日志输出情况,如图所示。
SpringBoot控制台启动日志(定制日志格式).png

Spring Boot 控制台启动日志的格式已经改成配置的格式。

3.4.3 配置日志输出级别

一般而言,系统的日志级别为 TRACE < DEBUG < INFO < WARN < ERROR <FATAL,级别逐渐提高。如果日志级别设置为 INFO,则意味着 TRACE 和 DEBUG 级别的日志都不会输出。

  • FATAL:致命等级的日志,指发生了严重的会导致应用程序退出的事件。
  • ERROR:错误等级的日志,指发生了错误,但是不影响系统运行。
  • WARN: 警告等级的日志,指发生了异常,可能是潜在的错误。
  • INFO: 信息等级的日志,指一些在粗粒度级别上需要强调的应用程序运行信息。
  • DEBUG:调试等级的日志,指一些细粒度的对于程序调试有帮助的信息。
  • TRACE:跟踪等级的日志,指一些包含程序运行详细过程的信息。

Spring Boot 通过 logging.level 配置项来设置日志输出级别。

下面通过示例演示 Spring Boot 日志输出级别。

LogDemo.java

package com.example.helloworld.log;import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;/*** Log级别测试类*/
@Configuration
public class LogDemo {/*** 一般而言,系统的日志级别为 TRACE < DEBUG < INFO < WARN < ERROR <FATAL,级别逐渐提高。如果日志级别设置为 INFO,则意味着 TRACE 和 DEBUG 级别的日志都不会输出。** FATAL:致命等级的日志,指发生了严重的会导致应用程序退出的事件。* ERROR:错误等级的日志,指发生了错误,但是不影响系统运行。* WARN: 警告等级的日志,指发生了异常,可能是潜在的错误。* INFO: 信息等级的日志,指一些在粗粒度级别上需要强调的应用程序运行信息。* DEBUG:调试等级的日志,指一些细粒度的对于程序调试有帮助的信息。* TRACE:跟踪等级的日志,指一些包含程序运行详细过程的信息。*/Logger logger = LoggerFactory.getLogger(getClass());@Beanpublic String logMethod() {logger.trace("LogDemo trace 日志...");logger.debug("LogDemo debug 日志...");logger.info("LogDemo info 日志...");logger.warn("LogDemo warn 日志...");logger.error("LogDemo error 日志...");return "hello log";}}

在上面的示例中,针对每个日志级别输出一行日志。我们可以调整输出的日志级别,让其只有在该级别以后的高级别生效。

(1)默认整个项目的日志级别为INFO

Spring Boot 默认整个项目的日志输出级别为 INFO。

启动项目验证日志输出情况,如图所示。
系统控制台启动日志(默认日志输出级别测试).png

如图所示,Spring Boot 控制台输出的系统启动日志级别为 INFO 级别,输出了 INFO、WARN 和 ERROR 的日志。

(2)指定整个项目的日志级别

配置日志输出级别,在 application.properties 中添加如下配置:

logging.level.root=WARN

在上面的示例中,我们使用 logging.level.root 指定整个项目的日志输出级别为WARN。

启动项目验证日志输出情况,如图所示。
系统控制台启动日志(配置整个项目的日志输出级别为WARN).png

如图所示,Spring Boot 控制台输出的系统启动日志级别为 WARN 级别,输出了 WARN 和 ERROR 的日志。

(3)对某个包指定单独的日志级别

配置日志输出级别,在 application.properties 中添加如下配置:

logging.level.root=INFO
logging.level.com.example.helloworld.log=WARN

在上面的示例中,我们将整个项目日志级别设置为INFO,同时将指定包com.example.helloworld.log下的日志级别设置为WARN。

启动项目验证日志输出情况,如图所示。
整个项目日志级别设置为INFO,同时将指定包com.example.helloworld.log下的日志级别设置为WARN).png

如图所示,Spring Boot 控制台输出的系统启动日志级别为 INFO 级别,输出INFO、WARN、ERROR日志;而com.example.helloworld.log包下LogDemo的日志级别设置为WARN,输出WARN、ERROR日志。

3.4.4 保存日志文件

一般情况下,在开发环境中习惯通过控制台查看日志,但是生产环境中需要将日志信息保存到磁盘上,以便于日后的日志查询。应该如何配置才能将日志信息保存到日志文件内呢?下面演示保存日志文件的过程。

在 resources 目录下的 applicaiton.properties 配置文件中添加如下配置项:

logging.file.name=E:/var/log/spring_log.log

在上面的示例中,我们使用 logging.file.name 指定日志文件的路径与名字。

重新启动项目,可以看到在 E:/var/log 目录下生成了 spring_log.log 文件,该文件的内容和控制台打印输出的内容一致,如图所示。
SpringBoot保存的日志文件.png

拓展

日志配置——logging.file.namelogging.file.path的使用区别?


(1)logging.file.name可以指定日志文件的路径与名字

示例:
logging.file.name=E:/var/log/spring_log.log
则该日志文件的路径为E:/var/log,日志文件的名字是spring_log.log

(2)logging.file.path可以指定日志文件的路径,而不能指定名字

示例:
logging.file.path=E:/var/log
则该日志文件的路径为E:/var/log,日志文件的名字是默认的spring.log

(3)logging.file.name和logging.file.path不能同时生效

在配置了两者的情况下,以logging.file.name为准。

来源:《Spring Boot 从入门到实战》学习笔记

http://www.yayakq.cn/news/299618/

相关文章:

  • 网站建设小组实训总结工作室网站源码php
  • 常熟网站建设都找聚尚网络网站开发惠州
  • 广州做网站app唐山市城乡建设局网站
  • 合肥滨湖建设指挥部网站我的家乡湛江网站设计
  • 哪里可以买链接网站策勒网站建设
  • 手机定制网站建设网络管理专业
  • 天河手机网站建设如何在wordpress底部添加友情链接
  • 个人备案做公司网站枣阳网站开发
  • 中国建设网官方网站6优化方案2022
  • php网站开发师条件茂名网站建设制作
  • 个人网站 虚拟主机企业电子商务网站建设规划
  • 网站建设模板下载免费建一个做笔记的网站
  • 做微信文章的网站网站建设排期表
  • 晋江企业网站开发深圳网站建设网页推广网站设计
  • 网站建设这个行业如何怎么申请注册公司
  • 九江广安建设网站个人网站需要哪些内容
  • 单页网站模板wap贷款申请入口
  • 南靖企业网站建设公司中文网站建设英文网站建设
  • 临淄网站制作首选专家深圳比较出名的互联网公司
  • 在微信怎样搞做微视频网站信阳做网站公司
  • 青岛设计公司排名应用商店搜索优化
  • 住房和城乡建设部网站住房补贴有哪些网页游戏网站
  • 做美食软件的视频网站做网站简单还是写程序
  • 建立soho公司网站杭州市造价网价格查询
  • 网站付款接口这么做wordpress站群插件
  • 网站建设使用的什么软件有哪些个人网站建设多少钱
  • 在西安建设工程交易中心网站wordpress文章页排版
  • 怎么自己创建一个免费网站成都学网站建设费用
  • 专业网站建设服务报价淘宝客必须建网站吗
  • 寻乌网站建设延吉最好的网站建设公司