SpringBoot 日志

article/2025/8/25 21:05:30

今天我们来学习日志,日志是啥玩意呢,其实我们之前使用过超简易版的日志,就是打印,我感觉大家应该都一样,使用打印来检查代码是不是执行到这里了,通过控制台打印的日志来发现问题,排查问题,但是随着我们的项目越来越大,日志有了更多的用途;

1,日志用途

1)系统监控

系统监控是一个程序系统的标配,会监控每个方法响应,运行的时间,一旦发生异常,超过阈值就会报警;

2)数据采集

这个是我们会把日志进行持久化,之后把这些数据交给大数据专业的人来处理,具体嘎哈呢,来猜你喜欢,比如你刷一个美女视频,你看了好几遍,接下来他就会根据这个日志给你疯狂的推送美女了;哈哈哈哈哈哈;

3)日志审计

这个就涉及到安全方面了,比如你干了些违法的事情,日志中是都有的,来保证一定的安全性,就比如有人删库跑路,维修人员也能根据日志来恢复数据库;


2,打印日志

我们来看看直接使用System.out.println(),和打印日志的区别:

我们看到我们打印的日志缺少了一堆东西,

Spring打的日志有时间,级别,进程ID,线程名,Logger名(源代码类名),日志内容,下面我们来看看Spring是怎么打印日志的:

    @RequestMapping("/Logger2")public void Logger2(){Logger logger = LoggerFactory.getLogger(LoggerController.class);logger.info("Logger2方法打印日志");}

这里的Logger要选择SLF4J的,

我们看看我们打印的日志:

跟Spring的是一样的; 


3,日志框架-门面模式

其实这个SLF4J很类似门面模式,日志的打印方式有很多,log4j,JUL,Logback,这些都是能够打印日志的,但是他们之间的配置文件是会发生冲突的,程序员们之前还要去解决配置文件的问题,很麻烦,但是出现了SLF4J就相当于出现了一个统一的遥控器,来控制这几个打印日志的东西,就不会涉及到配置文件的问题了;这就像门面模式的设计模式,我们之前还学过单例模式和工厂模式;

门面模式就是有三个功能的方法,我们创建了一个统一接口能够调用他们几个;

SLF4J就是其他日志框架的门面;


4,SLF4J框架介绍

就是其他日志框架的门面,我们比如要使用log4j,SLF4J就会把log4j的配置文件加载进去,我们就可以使用了;


5,日志格式的说明

1)时间

2)级别

3)进程ID

4)线程名

5)Logger日志名(源代码类名)

这里都简写了,就有首字母

6)日志内容


6,日志级别

日志的级别从高到低依次为:FATAL,ERROR,WARN,INFO,DEBUG,TRACE

FATAL:致命错误,通常是没有这个日志信息了,你都致命了还看什么日志呢

ERROR:错误信息,级别较高的错误信息,不影响系统的继续运行

WARN:警告信息,不影响使用,但需要注意的问题

INFO:普通信息,用于记录应用程序正常运行时的信息,比如启动完成,请求处理完成

DEBUG:调试信息,需要调试等待时候关键信息打印 

TRACE:追踪信息,比DEBUG更细粒度的信息(除非有特殊用意,否则使用DEBUG替代)

    @RequestMapping("/Logger3")public void Logger3(){logger.trace("trace日志");logger.debug("debug日志");logger.info("info日志");logger.warn("warn日志");logger.error("error日志");}

 我们来看看,

只打印了三个日志,那两个日志哪去了,这就要设计到日志的配置了,为啥看不到呢,我们可以来一个例子嗷,假如你是大老板,你需要知道公司的运营情况和一些重大事件,那计算机部门的张三今天吃榴莲了好难闻需要跟你汇报吗,就是这个道理,但是我们说我老板就是闲,我就要知道也不是不可以,我们修改配置文件就行了; 


7,日志配置

1)级别

我们先来学习配置日志的级别,我们就使用YML了嗷,还是喜欢用YML:
 

logging:level:root: trace

现在再来重新打印一下:

这个就不演示了,,,,,我启动了好久DEBUG都没打印完;

2)持久化

有两个方法:

1)配置日志的文件名

logging:file:name: Logger/SpringLogger.log

 

 这样我们的日志文件就存到这里了;

2)配置日志的存储目录

logging:file:path: C:\Spring日志

 这种方法创建的话名字是固定的:

这两种方式是冲突的,如果两种都存在会以name为准; 

3)分割

logging:logback:rollingpolicy:max-file-size: 10KBfile-name-pattern: ${LOG_FILE}.%d{yyyy-MM-dd}.%i

这样就是以10kb来分割日志:

 

我们这样就把日志分割成了两部分; 

4)格式

具体看板书


8,更简单的打印日志方式

有更简单的日志打印方式就是使用注解来进行打印,@SLF4J,完了直接使用log.info,我们需要添加lombok依赖:

<!-- https://mvnrepository.com/artifact/org.projectlombok/lombok -->
<dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId><version>1.18.30</version>
</dependency>
@RequestMapping("/Logger")
@RestController
@Slf4j
public class LoggerController {private static final Logger logger = LoggerFactory.getLogger(LoggerController.class);@RequestMapping("/Logger1")public void Logger1(){System.out.println("打印日志");}@RequestMapping("/Logger2")public void Logger2(){logger.info("Logger2方法打印日志");}@RequestMapping("/Logger3")public void Logger3(){logger.trace("trace日志");logger.debug("debug日志");logger.info("info日志");logger.warn("warn日志");logger.error("error日志");}@RequestMapping("/Logger4")public void Logger4(){log.info("使用注解打印日志");}}

 


http://www.hkcw.cn/article/qrxtawFCiW.shtml

相关文章

C语言——深入理解指针(1)

一、内存和地址 1.1 内存 在讲内存之前&#xff0c;我们先看一个生活中的案例&#xff1a; 假设有一栋宿舍楼&#xff0c;把你放在楼里&#xff0c;楼上有100个房间&#xff0c;但是房间没有编号&#xff0c;你的一个朋友来找你玩&#xff0c;如果想找到你&#xff0c;就得挨…

计算机操作系统(十四)互斥锁,信号量机制与整型信号量

计算机操作系统&#xff08;十四&#xff09;互斥锁&#xff0c;信号量机制与整型信号量 前言一、进程互斥与互斥锁1. 什么是进程互斥&#xff1f;2. 互斥锁是什么&#xff1f; 二、信号量机制&#xff08;解决互斥的更通用方案&#xff09;1. 为什么需要信号量&#xff1f;2. …

铸铁平台的优势和应用

铸铁平台是一种具有广泛应用的工业设备&#xff0c;其在各个领域均发挥着重要作用。本文将探讨铸铁平台的优势和应用&#xff0c;以帮助读者更好地了解这一重要设备。 一、铸铁平台的优势 强度高&#xff1a;铸铁平台采用高强度铸铁材料制成&#xff0c;具有优异的强度和耐磨性…

EfficMultiCoreMemoryPool项目

目录 1. 定长内存池介绍 2. tcmalloc整体框架了解 2.1 ThreadCache设计 各区间内存浪费分析 2.1.1 ThreadCache申请内存 2.1.2 ThreadCache释放内存 2.1.3 TLS线程局部变量 2.2 CentralCache设计 2.2.1 CentralCache申请内存 ThreadCache --> CentralCache的申请内…

【Doris基础】Apache Doris vs 传统数据仓库:架构与性能的全面对比

目录 1 引言 1.1 传统数据仓库的发展 1.2 现代分析型数据库的崛起 2 核心架构对比 2.1 传统数据仓库的架构 2.2 Doris的架构设计 3 关键技术差异 3.1 存储引擎对比 3.2 查询执行对比 3.3 数据摄入方式对比 4 性能与扩展性对比 4.1 性能基准对比 4.2 扩展性对比 5…

字符串转换函数-leetCode-008

问题描述&#xff1a; 实现一个将字符串转换为整数的函数时&#xff0c;需要考虑各种边界情况和细节&#xff0c;例如空格的处理、符号的判断、数字的读取以及整数溢出的处理等。以下是详细的解题过程以及代码实现。 问题分析 空格处理&#xff1a;需要丢弃字符串开头的空格字…

深度学习目标检测实战——YOLOv8从入门到部署

本文将手把手带你用 YOLOv8&#xff08;目前非常先进的目标检测框架&#xff09;实现从数据标注到模型部署的全流程实战&#xff0c;并达到工业级检测精度&#xff01; [yolo视频教程&#xff0c;戳蓝字即可学习] 这才是科研人该学的【YOLO算法全系列】&#xff0c;一口气学完…

C#对象集合去重的一种方式

前言 现在AI越来越强大了&#xff0c;有很多问题其实不需要在去各个网站上查了&#xff0c;直接问AI就好了&#xff0c;但是呢&#xff0c;AI给的代码可能能用&#xff0c;也可能需要调整&#xff0c;但是自己肯定是要会的&#xff0c;所以还是总结一下吧。 问题 如果有一个…

[ctfshow web入门] web124

信息收集 error_reporting(0); //听说你很喜欢数学&#xff0c;不知道你是否爱它胜过爱flag if(!isset($_GET[c])){show_source(__FILE__); }else{//例子 c20-1$content $_GET[c];// 长度不允许超过80个字符if (strlen($content) > 80) {die("太长了不会算");}/…

AI生成思维导图全技术解析

一、AI生成思维导图的底层技术逻辑 (一)知识结构化的核心流程 AI生成思维导图的本质是非结构化文本到结构化知识图谱的转化,其技术流程可拆解为五大核心环节: 1. 语义解析与实体抽取 多模态输入处理:支持文本(Markdown/Word/PDF)、语音(会议录音)、手写笔记(图片O…

秋招Day12 - 计算机网络 - 网络综合

从浏览器地址栏输入URL到显示网页的过程了解吗&#xff1f; 从在浏览器地址栏输入 URL 到显示网页的完整过程&#xff0c;并不是一个单一的数据包从头到尾、一次性地完成七层封装再七层解析的过程。 而是涉及到多次、针对不同目的、与不同服务器进行的、独立的网络通信交互&a…

SpringBoot集成第三方jar的完整指南

原文地址&#xff1a;https://blog.csdn.net/weixin_43826336/article/details/141640152?ops_request_misc%257B%2522request%255Fid%2522%253A%25227d4118ef2d572ba4428caf83f1d2bb28%2522%252C%2522scm%2522%253A%252220140713.130102334…%2522%257D&request_id7d4118…

官宣开源!通过 AI 驱动的前后端 Java Vue 脚手架(AI 后台管理)正式发布!

&#xff08;在本帖评论点赞关注的小伙伴&#xff0c;今日可得好运相随&#xff0c;会有好事发生&#xff0c;不信试试看&#xff5e;&#xff09; &#x1f525; 知路后台管理 - 通过 AI 驱动的新一代前后端脚手架 知路是一个原生集成 AI 并通过 AI 驱动的重新构思、重新设计…

什么是VR全景相机?如何选择VR全景相机?

VR全景相机的定义、原理及特点 定义&#xff1a;VR全景相机是利用特殊镜头设计和图像处理技术&#xff0c;能够捕捉到360度全方位、无死角的高清影像&#xff0c;并通过虚拟现实技术将用户带入沉浸式全景环境的相机设备。 原理&#xff1a;VR全景相机通过集成多个鱼眼镜头&am…

vr中风--数据处理模型搭建与训练2

位置http://localhost:8888/notebooks/Untitled1-Copy1.ipynb # -*- coding: utf-8 -*- """ MUSED-I康复评估系统&#xff08;增强版&#xff09; 包含&#xff1a;多通道sEMG数据增强、混合模型架构、标准化处理 """ import numpy as np impor…

数控技术应用理实一体化平台VR实训系统

::产品概述:: 目前我国本科类院校学生普遍存在的问题就是缺少对实际工作的了解&#xff0c;一直在学习相关专业的理论知识&#xff0c;对社会的相关企业的用人情况不了解。这也就直接导致了毕业的学生和社会上的用人单位需求有点脱节&#xff0c;这也是由于我国的现行本科教育侧…

上传图片转成3D VR效果 / 用photo-sphere-viewer实现图片VR效果

系统简介 : 该系统为 react TS tailwindcss photo-sphere-viewer 的响应式 VR360 项目, 上传图片后可实现手动旋转 3D 图片,还包含了 6 贴图立方体展示和 6 贴图动态展示 目前为单图切换模式 全部页面概览 这是单面VR页面的代码(gif展示页面) import React, { useRef, u…

若依微服务的定制化服务

复制依赖 复制依赖 复制system服务的bootstrap.yml文件&#xff0c;修改port和name 在nacos复制一个新的nacos配置&#xff0c;修改对应的nacos的配置 &#xff0c;可能不需要修改&#xff0c;看情况。 网关修改 注意curd的事项&#xff0c;模块名称的修改

python和风api获取天气(JSON Web Token)

下载安装openssl 默认安装目录&#xff0c;添加C:\Program Files\OpenSSL-Win64\bin到用户Path环境变量 打开cmd&#xff0c;执行命令&#xff0c;会生成两个文件ed25519-private.pem&#xff0c;ed25519-public.pem openssl genpkey -algorithm ED25519 -out ed25519-privat…

【案例分享】蓝牙红外线影音遥控键盘:瑞昱RTL8752CJF

蓝牙红外线影音遥控键盘 Remotec的无线控制键盘采用瑞昱蓝牙RTL8752CJF解决方案&#xff0c;透过蓝牙5.0与手机配对后&#xff0c;连线至 Remotec 红外 code server 取得对应影音视觉设备的红外 code后&#xff0c;即可控制多达2个以上的影音视觉设备&#xff0c;像是智能电视…