Spring日志

Spring日志的作用:

1.定位和发现问题
2.系统监控
3.数据采集

4.日志审计
 

打印日志步骤:
1.定义日志对象2.打印日志


@RestController
public class LoggerController {


    private static Logger  logger= LoggerFactory.getLogger(LoggerController.class);

    @PostConstruct
    public void print(){

        System.out.println("打印日志");
        logger.info("日志框架****************88");
    }
}

其显示地方与平常打印的地方有很大差别

上述红色字就代表了其的具体信息,日志对象的名称,可能为缩写。通常情况下,是当前类

Spring 默认的日志级别是info
可以在配置中去控制日志级别

门面模式(外观模式)
slf4j是门面模式的典型的应用.

日志框架: SLF4J
他不是一个真实的日志框架,只是一个日志框架的代表(门面模式)框架里面的具体内容是由log4j/log4j2/logback/jul实现的。

SLF4J提供了一个简单的、统一的API,用于在Java应用程序中进行日志记录。它允许开发人员使用统一的代码编写日志记录语句,而不需要关心底层日志框架的具体实现。SLF4J充当了一个门面(Facade),隐藏了底层日志框架(如Logback、Log4j、java.util.logging等)的细节,使得开发人员可以在不改变代码的情况下轻松地切换和配置不同的日志实现。

SLF4J的设计符合门面模式的核心思想:提供一个简单的接口,隐藏底层复杂性。通过SLF4J,开发人员可以在应用程序中使用统一的日志API,而不需要关心具体的日志实现,这样就降低了应用程序的耦合度,并且使得日志记录变得更加灵活和易于管理。因此,SLF4J被认为是门面模式在Java日志记录领域的典型应用。

日志持久化
数据保存在数据库中,是一种持久化的方式

曰志保存在文件中,也是一种持久化的方式

日志保存到文件中的话可以用相对路径,也可以使用绝对路径

name既可以设置路径,又可以设置名称path只能设置路径,默认名称是: spring.log

如果二者同时存在, path 就失效了
name的优先级要高于path
 

logging:
  file:
#    name: logger/ioc.log
     path: logger1

日志文件分割的名称定义规则日志最大文件

logging: 
 logback:
    rollingpolicy:
      max-file-size: 1KB

不是达到1KB就立刻进行分割的以行来分割,不是以字符分割的


企业中,通常日志分割大小为200M或者500M

         

修改控制台日志格式
 

logging: 
 pattern:
    console: "%d{HH : mm : ss.SSS} %c %H %L[%thread]%m%n"

修改日志格式

logging:
  pattern:
    file: "%d{HH : mm : ss.SSS} %c %H %L [%thread] %m%n"

加上@slfj4注解

在类中打印日志不用重复写写log对象的创建,之后会自动进行创建一个log对象来书写日志

相关推荐

  1. spring boot-

    2024-04-29 00:08:02       31 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-04-29 00:08:02       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-04-29 00:08:02       101 阅读
  3. 在Django里面运行非项目文件

    2024-04-29 00:08:02       82 阅读
  4. Python语言-面向对象

    2024-04-29 00:08:02       91 阅读

热门阅读

  1. 实验报告4-MyBatis与Spring的整合

    2024-04-29 00:08:02       37 阅读
  2. Fiddlers使用

    2024-04-29 00:08:02       32 阅读
  3. Android Native Hook: 原理、方案对比与具体实现

    2024-04-29 00:08:02       37 阅读
  4. 将mysql转为oracle

    2024-04-29 00:08:02       33 阅读
  5. LeetCode题练习与总结:组合-77

    2024-04-29 00:08:02       37 阅读
  6. new qemu QEMU_OPTION_d

    2024-04-29 00:08:02       25 阅读
  7. 笨蛋学C++【C++基础第八弹】

    2024-04-29 00:08:02       30 阅读
  8. C语言基础—多线程基础

    2024-04-29 00:08:02       33 阅读
  9. YOLOV5 TensorRT部署 BatchedNMS(转换engine模型)(上)

    2024-04-29 00:08:02       36 阅读
  10. 在Docker中为Nginx容器添加多端口映射的详细指南

    2024-04-29 00:08:02       29 阅读
  11. 描述一下PHP中的MVC设计模式

    2024-04-29 00:08:02       29 阅读
  12. Linux系统使用命令来查看本地端口的使用情况

    2024-04-29 00:08:02       32 阅读