Spring日志框架

本文涉及的产品
日志服务 SLS,月写入数据量 50GB 1个月
简介: Spring日志框架

前言

本文我们简单说说关于Spring中的日志框架,以及对应的注解

我们知道,公司服务器在运行的时候,一定会打印日志,有很多优点,比如预防报警,或者是某重大事故尝试修复等等都需要查看日志

应该说日志对我们来说并不陌生,我们在之前刷题或者是程序遇到bug的时候也经常会将程序的状态等打印在控制台上

但是随着项目的复杂度的增加,仅仅使用System.out,print语句已经不能满足我们了,我们需要更加专业的一些日志框架来帮助我们解决问题

本篇我们就将讲解一个Spring引入的外部框架,简单好用

就像我们平常控制台上的日志一样,可以体现更多的信息

日志的用途

我们首先知道日志是发现问题解决问题的

但是日志不仅仅只支持这几个功能,他的功能甚至更加强大

比如日志还有以下功能

1.系统监控

   通过日志监控一个系统的运行状态,每一个方法的响应时间,响应状态的设置不同的规则,超过规则达到一定阈值进行报警啊等等等

2.数据采集

        统计页面的浏览量,从而可以设置主页的推荐排序啊等等

3.日志审计

        这就涉及国家要检查企业的日志等等,涉及一些网络安全问题

日志的使用

首先我们来介绍一下启动spring的时候系统生成的日志

这里的每一条日志都是由 时间 + 日志级别 + 进程号 + --- + 项目名 + 线程名 + Logger名(通常使用源代码的类名) + 日志内容

其中日志的等级分为

FATAL,ERROR,WARN,INFO,DEBUG,TRACE

注:这里的日志级别主要是给不同的人来过滤信息使用的

FATAL:需要立即被处理的系统级别错误

ERROR:需要出来,但是不影响系统的持续运行

WARN:不影响使用,但是需要注意

INFO:普通信息,比如请求完成等

DEBUG:调试信息,一般不显示

TRACE:比DEBUG更细粒度的调试信息

级别越高,收到的信息越少

下面我们来打印点自己的日志瞅瞅

我们发现这里INFO以下级别的日志根本没有被打印出来

注:SpringBoot的默认日志框架是logback,logback中不存在fatal级别,他被逻辑映射到了error中

我们发现这里并没有出现DEBUG级别和TRACE级别的日志,这是因为Spring的默认参数设置是INFO级别,只会显示这个级别以上的日志文件,我们如果想看到低级别的日志可以去配置文件中修改参数即可

将logger.level修改成debug就可以看到debug及以上的信息了

设计模式

日志这里涉及两个设计模式

工厂模式和门面模式

由于我们在之前介绍过工厂模式,这里就做过多赘述了

我们这里简单介绍一下门面模式(又称外观模式)

我们这里使用的框架叫做SLF4J 这就是一个日志的门面

主要做的事情就是让客户端减少和底层的直接交互,而是通过这个抽象层,访问子系统的一堆接口,降低了其中的耦合性,定义了一个高层接口,让子系统更容易被使用

比如你家的智能家居

你可以通过手机上的软件来直接操作家里的各种电器,而不需要使用底层电器的直接开关

日志的持久化

日志通常是不断产生的,我们需要将日志持久化到文件中,以便于保存或者出现问题的时候及时查看 ,所以我们需要将日志持久化到文件中保存

这里在文件中设置配置保存的路径或者文件名即可

这里我们的配置可以使用两种

1.使用路径 + 文件名

比如  logging.file.name    就会发现在项目中多了一个文件夹和一个文件

2.使用路径(不支持文件名,这里使用文件名会被当做文件路径)

logging.file.path  这里不管使用什么后缀都不会生效

注解方式使用日志

我们只需要导入lombok的依赖即可使用

加入一个@slf4j注解即可,其实现和工厂模式的实现相同,我们可以查看idea给的反编码

查看官方文档

点击官方文档,

相关实践学习
日志服务之使用Nginx模式采集日志
本文介绍如何通过日志服务控制台创建Nginx模式的Logtail配置快速采集Nginx日志并进行多维度分析。
相关文章
|
22天前
|
前端开发 Java 数据库连接
Spring框架初识
Spring 是一个分层的轻量级开源框架,核心功能包括控制反转(IOC)和面向切面编程(AOP)。主要模块有核心容器、Spring 上下文、AOP、DAO、ORM、Web 模块和 MVC 框架。它通过 IOC 将配置与代码分离,简化开发;AOP 提供了声明性事务管理等增强功能。
73 21
Spring框架初识
|
3月前
|
XML 安全 Java
|
4月前
|
缓存 NoSQL Java
什么是缓存?如何在 Spring Boot 中使用缓存框架
什么是缓存?如何在 Spring Boot 中使用缓存框架
169 0
|
13天前
|
存储 人工智能 开发框架
Spring AI Alibaba 应用框架挑战赛圆满落幕,恭喜获奖选手
第二届开放原子大赛 Spring AI Alibaba 应用框架挑战赛决赛于 2 月 23 日在北京圆满落幕。
|
2月前
|
SQL Java 数据库连接
对Spring、SpringMVC、MyBatis框架的介绍与解释
Spring 框架提供了全面的基础设施支持,Spring MVC 专注于 Web 层的开发,而 MyBatis 则是一个高效的持久层框架。这三个框架结合使用,可以显著提升 Java 企业级应用的开发效率和质量。通过理解它们的核心特性和使用方法,开发者可以更好地构建和维护复杂的应用程序。
137 29
|
1月前
|
XML Java 开发者
通过springboot框架创建对象(一)
在Spring Boot中,对象创建依赖于Spring框架的核心特性——控制反转(IoC)和依赖注入(DI)。IoC将对象的创建和管理交由Spring应用上下文负责,开发者只需定义依赖关系。DI通过构造函数、setter方法或字段注入实现依赖对象的传递。Spring Boot的自动配置机制基于类路径和配置文件,自动为应用程序配置Spring容器,简化开发过程。Bean的生命周期包括定义扫描、实例化、依赖注入、初始化和销毁回调,均由Spring容器管理。这些特性提高了开发效率并简化了代码维护。
|
5天前
|
存储 监控 数据可视化
SaaS云计算技术的智慧工地源码,基于Java+Spring Cloud框架开发
智慧工地源码基于微服务+Java+Spring Cloud +UniApp +MySql架构,利用传感器、监控摄像头、AI、大数据等技术,实现施工现场的实时监测、数据分析与智能决策。平台涵盖人员、车辆、视频监控、施工质量、设备、环境和能耗管理七大维度,提供可视化管理、智能化报警、移动智能办公及分布计算存储等功能,全面提升工地的安全性、效率和质量。
|
2月前
|
开发框架 运维 监控
Spring Boot中的日志框架选择
在Spring Boot开发中,日志管理至关重要。常见的日志框架有Logback、Log4j2、Java Util Logging和Slf4j。选择合适的日志框架需考虑性能、灵活性、社区支持及集成配置。本文以Logback为例,演示了如何记录不同级别的日志消息,并强调合理配置日志框架对提升系统可靠性和开发效率的重要性。
|
3月前
|
设计模式 XML Java
【23种设计模式·全精解析 | 自定义Spring框架篇】Spring核心源码分析+自定义Spring的IOC功能,依赖注入功能
本文详细介绍了Spring框架的核心功能,并通过手写自定义Spring框架的方式,深入理解了Spring的IOC(控制反转)和DI(依赖注入)功能,并且学会实际运用设计模式到真实开发中。
【23种设计模式·全精解析 | 自定义Spring框架篇】Spring核心源码分析+自定义Spring的IOC功能,依赖注入功能