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对象来书写日志

  • 5
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值