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

Java Spring日志

文章目录

  • Spring日志
    • 日志的作用
      • 观察日志
      • 日志框架
      • 日志的级别
      • 总结
      • 日志级别
      • 日志的持久化
      • 日志分割
      • 修改日志的格式
      • 日志的简单写法
    • 总结

Spring日志

  1. jar包和war包的区别:
    JAR包是Java类库的归档文件,而WAR包是专门用于Web应用程序的归档文件。

  2. 热加载:写的代码,立即被加载进来,生效了
    热部署:如果代码发生了变动,就会重新部署

  3. 运行SpringBoot程序(不在idea上运行的情况)
    (1) 打jar包
    (2) 通过java -jar XXX.jar
    启动Java虚拟机,并运行一个打包好的、名为 XXX.jar 的Java应用程序

  4. 如果要修改application.properties或者是application.yml文件的名字,就需要指定配置文件,但是我们一般不会进行修改,如下:
    在这里插入图片描述

日志的作用

日志就是数据

  1. 定位和发现问题
  2. 系统监控
    比如618的京东,就在监控屏上看数据的响应,10条请求,就有10条响应,10条数据,0条响应,就是有问题的
  3. 数据采集:例如大数据等
  4. 日志审计:系统收集采集到的数据,以达到安全监控、故障排查、合规性验证和运营优化的目的

观察日志

  1. Spring集成了日志框架
    在这里插入图片描述
  2. 引用slf4里的包
    在这里插入图片描述
  3. 使用框架打印日志:
package com.example.ioc.demos.controller;import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.web.bind.annotation.RestController;import javax.annotation.PostConstruct;@RestController
public class LoggerController {// 通过日志工厂拿到了日志private static Logger logger = LoggerFactory.getLogger(LoggerController.class);// 初始化@PostConstructpublic void print(){System.out.println("打印日志!");logger.info("++++++++++++++我是日志框架打印的日志++++++++++++++++");}
}

在这里插入图片描述
打印出来的日志内容:
在这里插入图片描述
这个类来自于我们写的类,使用工厂模式打印日志:
在这里插入图片描述

日志框架

  1. slf4j 并不是一个真实的日志实现,而是日志门面,具体实现是log4j I/2 ,logback等
    使用SLF4J门面就可以,不需要关注它的具体实现,降低了代码之间的耦合
    在这里插入图片描述
    SLF4J是一个日志的门面,只需要知道门面的使用即可,不用了解它的日志实现,Spring主要使用的日志实现是logback
  2. 门面模式(外观模式)
    slf4j 是门面模式的典型的应用。
    门面模式(有称为外观模式),提供了一个统一的接口,用来访问子系统中的一群接口。其主要特征是定义一个高层接口,让子系统更容易使用,不需要关注子系统中的实现和内容。
    在这里插入图片描述
    举个例子:
    在这里插入图片描述

在这里插入图片描述
面试问:什么是设计模式??
设计模式:就是解决问题的一种模式,如何设计解决问题(解决问题的套路就是模式)
3. 门面模式的优点:
在这里插入图片描述
4. 入引入日志门面存在的问题:
在这里插入图片描述
5. 引入日志门面:
在这里插入图片描述
6. 打印日志的类(通常是当前这个类):
在这里插入图片描述

日志的级别

  1. 日志的分类:
    出现FATAL就等于是公司破产了
    在这里插入图片描述
  2. Spring默认的日志级别是 info,所以比info级别低的日志不打印出来
    在这里插入图片描述
    也可以设置日志的级别,在配置文件中,就可以设置
// 将最低日志级别设置为了debug,比debug高的日志可以打印出来,比debug
// 级别低的还是打印不出来
logging:level:root: debug

总结

  1. 日志的使用:
    在这里插入图片描述

  2. 日志框架:
    在这里插入图片描述
    举个门面模式的例子:
    在这里插入图片描述

日志级别

  1. debug会打印较多日志,可以对日志进行分目录打印,减少打印的内容
    在这里插入图片描述
  2. 设置颜色:
    日志不仅可以再控制台中,还可以在消息队列,文件中
    日志可以设置颜色,只能设置控制台的颜色,这不是日志的支持,而是idea的支持

(1) 启动类设置
在这里插入图片描述
(2) 添加VM options
在这里插入图片描述

-Dspring.output.ansi.enabled=ALWAYS

日志的持久化

  1. 数据保存在数据库中,是一种持久化的方式,日志保存在文件中,也是一种持久化的方式

(1) 保存在文件中
在这里插入图片描述

logging:level:root: info #设置Spring打印的级别,root表示所有(我自己的项目和Spring管理的)都是info权限com:example:ioc:demos: debug # 设置我们自己的项目的级别file:name: logger/ioc.log
#    path: logger1

如果没有加路径,默认是放在当前项目下

在这里插入图片描述

在这里插入图片描述
放在相对路径下:
在这里插入图片描述
SpringBoot的特点:约定大于配置

path只可以设置路径:
在这里插入图片描述

在这里插入图片描述

日志分割

  1. 如果日志非常大就不好读了,所以要对日志进行分割
logging:# 日志分割logback:rollingpolicy:max-file-size: 1KB # 1KB就进行分割文件file-name-pattern: ${LOG_FILE}.%d{yyyy-MM-dd}.%i# 修改文件的命名格式

在这里插入图片描述
2. 文件分割的要求:
在这里插入图片描述

修改日志的格式

  1. 修改控制台和文件的日志格式:
    在这里插入图片描述
# 控制台日志格式
logging.pattern.console
# 日志文件格式
logging.pattern.file# 修改日志格式pattern:console: '%d{ HH:mm:ss.SSS} %c %M %L [%thread] %m%n'file: '%d{ HH:mm:ss.SSS} %c %M %L [%thread] %m%n'

控制台日志格式:
在这里插入图片描述

日志的简单写法

  1. 使用@Slf4j
    在这里插入图片描述
    在这里插入图片描述
  2. @Sl4j 是lombok工具包提供的
    在这里插入图片描述
  3. @Slf4
    在这里插入图片描述
    在这里插入图片描述

总结

在这里插入图片描述

http://www.dtcms.com/a/494842.html

相关文章:

  • OpenAI Agent Kit 全网首发深度解读与上手指南
  • 网络:2.Socket编程UDP
  • Linux服务器编程实践45-UDP数据读写:recvfrom与sendto函数的使用实例
  • 基于SpringBoot+Vue的数码交流管理系统(AI问答、协同过滤算法、websocket实时聊天、Echarts图形化分析)
  • 设计模式篇之 状态模式 State
  • linux系统编程(十)RK3568 socket之 UDP的实现
  • MySQL事务隔离
  • 甜点的网站建设规划书长春市城乡建设局网站
  • C++ 多线程实战 11|如何系统性避免死锁
  • WAPR断网攻击天阶大法根基法之wifi爆破
  • 集群冗余:高可用的核心设计
  • Vue 3 完全指南:响应式原理、组合式 API 与实战优化
  • Netscape 浏览器
  • 笔记:TFT_eSPI不支持ESP32C6;ESP8266运行LVGL注意事项
  • 会网站开发没学历seo网络营销
  • 简述深度学习中的四种数据并行方法(DP,DDP,TP,PP)
  • YOLO-World 全面解析:实时开放词汇目标检测的新范式(附实践指南)
  • 西瓜网络深圳网站建设 东莞网站建设电商型网站
  • AI+大数据时代:时序数据库的生态重构与价值跃迁——从技术整合到行业落地
  • 设计素材网站图案免费建设银行社保卡网站在哪
  • 预告!星火社吕诚将推 “星星之火” 线上课堂,哲思 + 投资赋能公益新生态
  • 孟德尔随机化 哪个计算最消耗时间 在肠道菌群、代谢物和疾病三类数据中,**肠道菌群数据的处理通常最消耗时间**
  • 【Redis学习】持久化机制(RDB/AOF)
  • 栈式自编码器(Stacked Auto-Encoder)
  • 像wordpress一样的网站建设银行网站转账必须u盾吗
  • 让低端机也能飞:Canvas/WebGL/Viz 分层、降级渲染与数据抽样策略
  • 【grafana查询超时问题】
  • 广播系统配线-批量测量快速计算
  • 电商网站商品页的优化目标是什么?第一推是谁做的网站
  • 从零开始的C++学习生活 9:stack_queue的入门使用和模板进阶