Java EE 突击 9 - Spring Boot 日志文件

Spring Boot 日志文件

  • 学习目标
  • 一 . 日志有什么用
    • 1.1 日志格式说明
  • 二 . 自定义日志打印
    • 2.1 得到日志对象
    • 2.2 使用日志对象提供的方法 , 输出自定义的日志内容
    • 2.3 日志的级别
  • 三 . 日志持久化
    • 3.1 在配置文件里面设置日志名称
    • 3.2 设置日志的保存目录
  • 四 . 日志级别的设置
  • 五 . 简化日志的小技巧 - lombok
    • 5.1 lombok 的使用
    • 5.2 lombok 的原理
    • 5.3 lombok 更多注解说明
  • 总结

这个专栏给大家介绍一下 Java 家族的核心产品 - SSM 框架
JavaEE 进阶专栏

Java 语言能走到现在 , 仍然屹立不衰的原因 , 有一部分就是因为 SSM 框架的存在

接下来 , 博主会带大家了解一下 Spring、Spring Boot、Spring MVC、MyBatis 相关知识点

并且带领大家进行环境的配置 , 让大家真正用好框架、学懂框架

来上一篇文章复习一下吧
点击即可跳转到我的小秘密
在这里插入图片描述

学习目标

  1. 输出自定义日志信息
  2. 将日志持久化
  3. 通过设置日志的级别来筛选和控制日志的内容

一 . 日志有什么用

日志只有一个作用 : 发现问题 定位问题
我们之前已经使用了很多次的日志
image.png
除了发现和定位问题之外,我们还可以通过日志实现以下功能:

  • 记录用户登录日志,方便分析用户是正常登录还是恶意破解用户。
  • 记录系统的操作 , 方便数据恢复和定位操作。
  • 记录程序的执行时间 , 方便为以后优化程序提供数据支持。

1.1 日志格式说明

image.png
日志打印级别 : 用来筛选有效信息

在日常调试和开发过程中 , 我们需要看的日志通常会比较多 , 在生产环境的时候 , 我们并不需要看调试日志以及开发日志 , 我们就可以把他屏蔽掉 , 也可以把 Spring Boot 展示给我们的日志(INFO) 也关闭掉 , 只展示报错以及警告信息 , 那么我们就可以通过日志的级别来进行筛选关键信息 . 而且打印日志也是会消耗一定资源的 , 所以在线上环境就尽量别弄出什么幺蛾子了 .

通过目前我们了解到的日志 , 我们发现三个问题 :

  1. 这是 Spring Boot 默认的日志格式 , 目前我们打印出的都是系统自己的日志 , 那么我们怎么样能让控制台打印我们自己的日志 ?
  2. 我们的日志是保存在我们的内存上的 , 那么假如我们的线上环境出现了问题 , 我们也不能说让人一直去看着 , 出现问题赶紧把开发人员叫过来查看日志 , 所以日志的持久化保存也是非常有必要的
  3. 我们需要通过日志的级别来筛选我们需要的信息

二 . 自定义日志打印

自定义日止的实现步骤 :

  1. 在程序中得到日志对象
  2. 使用日志对象的相关语法输出要打印的内容

我们思考一个问题 : 使用 sout 语句能否替代日志呢 ?
TestController.java

package com.example.demo.aa.bb;import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;// 这个注解什么意思先不用管
@RestController
public class TestController {// 这个注解什么意思先不用管@RequestMapping("/sayhi")public String sayHi() {System.out.println("这里正在测试日志");return "日志";}
}

我们这不也打印出相关信息了吗 ?
image.png
但是感觉跟正常的日志差得有点多 , 感觉不太靠谱

  1. 只有打印的内容 , 没有其他的相关信息 , 比如打印的时间、打印的类(出处)
  2. 不能实现不同环境下的行为控制

比如我们的日志能够通过日志级别筛选 , 让线上环境或者开发环境展示出不同的信息 , 而 sout 语句不行 , 他会在哪里都打印的

所以使用 sout 语句是不能替代日志的 , 还是需要专业的人干专业的事的

2.1 得到日志对象

导入 Logger 对象
注意 : 一定要选择 org.slf4j (飒楼否四节)
然后使用 Logger 的 LoggerFactory 里面的 getLogger 方法, 参数填写当前类.class
image.png
image.png
image.png

2.2 使用日志对象提供的方法 , 输出自定义的日志内容

使用 log. 的方式 , 接下来我们就可以打印日志了

package com.example.demo.aa.bb;import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;@RestController
public class TestController {// 1. 得到日志对象private static Logger log = LoggerFactory.getLogger(TestController.class);@RequestMapping("/sayhi")public String sayHi() {// 2. 打印日志log.info("Hi,Spring Boot Log.");//使用日志对象的方法输出日志return "日志";}
}

image.png
那么我们上面告诉大家一定要用 slf4j , 那么 slf4j 是个什么东西 ?
我们的 slf4j 与 Spring Boot 是密切相关的 , slf4j 也是目前行业中的日志标杆了 , 他的日志以我们目前对于 Spring Boot 的理解来说 , 还算是比较复杂的 . 但看似很简单的日志 , 其实是由两部分实现的
image.png
我们可以这样理解 : 日志门面就是前端 , 日志实现就是后端
为什么一个简简单单的日志还要分解为日志门面还有日志实现呢 ?
最刚开始 , 其实日志是不分类的 , 后来发现了一个问题 : 我们的代码通用性问题 , 假如我们最开始用 log4j 1/2 , 但是后来他就出现漏洞了 , 所以大家又转战到了 logback , 但是使用 logback 就出现了问题 : 我们之前所有调用日志代码的地方就需要去更改 , 这样日志就没有通用性了 , 所以我们就再抽象一层 , 我们是从 slf4j 使用的 , slf4j 会自己帮我们解决好适配性问题 , 提高代码的移植性
其实和我们 JDBC 的问题是一样的 , 大家都是为了能够提高代码的通用性

2.3 日志的级别

我们不光可以打印普通日志 , 还可以打印其他等级的日志

package com.example.demo.aa.bb;import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;@RestController
public class TestController {// 1. 得到日志对象private static Logger log = LoggerFactory.getLogger(TestController.class);@RequestMapping("/sayhi")public String sayHi() {// 2. 打印日志// 级别从上到下逐个提升的log.trace("Hi,I am trace.");//痕迹日志log.debug("Hi,I am debug.");//调试日志log.info("Hi,I am info.");//普通日志log.warn("Hi,I am warn.");//警告日志log.error("Hi,I am error");//报错return "日志";}
}

image.png
那为什么剩下两个没被打印呢 ?
这是因为默认情况下日志级别是 info , 所以就把 trace debug 筛选下去了
那么我们都有哪些级别的日志呢 ?
image.png

  • trace:微量,少许的意思,级别最低;
  • debug:需要调试时候的关键信息打印;
  • info:普通的打印信息;
  • warn:警告,不影响使用,但需要注意的问题;
  • error:错误信息,级别较高的错误日志信息;
  • fatal:致命的,因为代码异常导致程序退出执行的事件。

那么我们上面只打印出来五种啊 , 咋没打印第六种 .
image.png
可以看到 , 我们是调用不出来 fatal 的 . 这种致命的错误不是你说调就调出来的 , 当发生异常情况导致终止的时候才能看到 fatal , 甚至说严重点 , 还没有多少人见过他的芳容 .

三 . 日志持久化

3.1 在配置文件里面设置日志名称

我们在 application.yml 里面添加这句配置项

# 设置日志文件的文件名
logging:file:name: springboot.log

接下来运行查看一下效果
image.png
还可以这样去看
image.png
image.png
image.png
如果有的同学没看见日志在哪里 , 可以把 target 文件夹删除 , 重新运行再来看
image.png
接下来 , 我们就可以把项目停掉 , 来看一下咱们的日志
image.png
那么我们重新运行 , 新的日志是追加在后面还是覆盖掉 ?
肯定是追加在后面 , 不然还是有日志丢失的风险 .
重新运行后的日志就变多了
image.png
那么日志一直追加 , 越来越大 , 打开的速度就会变得非常慢 , 寻找日志就比较麻烦 , 那怎么办呢 ?
当日志比较大的时候 , 会自动分割成多个文件 , 所以不用去担心

3.2 设置日志的保存目录

# 设置日志文件的目录
logging:file:path: D:\study\JavaCode

我们打开这个目录看一下是否真的生成了 ?
image.png
那么我们把程序停止 , 看看日志里面有什么 ?
image.png
那么这种方式能不能追加日志呢 ?
也是可以追加的
image.png

四 . 日志级别的设置

日志级别的设置非常的精细化 , 可以针对于某个目录设置日志级别 , 还可以设置一个全局的日志级别
日志级别配置只需要在配置文件中设置 “logging level” 配置项即可

logging:level:root: debug

image.png
注意 : 我们之前写过 logging , 要是再写一个 logging 的话就会报错
image.png
所以我们可以在一个 logging 标签底下写多个配置项

logging:file:path: D:\study\JavaCodelevel:root: warn # 根路径

那么有的人只想看到自己的 DEBUG 日志 , 不想看到 Spring 的 DEBUG 日志 , 因为 Spring 的 DEBUG 日志实在是太多了 , 那么我们就可以把系统日志设置的级别高一些 , 可以让 Spring 的日志级别设置成 warn , 我们自己的代码的日志级别设置成 debug

logging:file:path: D:\study\JavaCodelevel:root: warn # 根路径com:example:demo: debug # com.example.demo 下面的所有类,日志级别都是 debug

image.png
那么我们想要自己的日志级别为 trace , 系统日志为 warn 怎么处理呢 , 同样很简单

logging:file:path: D:\study\JavaCodelevel:root: warn # 根路径com:example:demo: trace

image.png


接下来 , 我们模拟一下真实的开发环境
上节课我们学过多平台的配置文件设置 , 那么我们就可以根据不同的环境打印出不同等级的日志了
首先 , 我们创建出三个不同的环境的配置文件

开发环境的配置文件 : application-dev.yml
测试环境的配置文件 : application-test.yml
生产环境的配置文件 : application-prod.yml

然后我们分别在每个配置文件中设置不一样的端口 , 方便我们后续测试效果
image.png
然后接下来设置每个环境的日志等级
开发环境设置成系统日志为 warn , 自己的日志为 debug
测试环境设置成系统日志为 warn , 自己的日志为 info
生产环境设置成系统日志为 warn , 自己的日志为 warn
image.png
接下来在我们总的配置文件中调用每个单独的配置文件

# 运行环境设置
spring:profiles:active: dev

记得这里要去浏览器访问 127.0.0.1:8888/sayhi, 因为我们的开发环境配置文件端口号是 8888
image.png
这次访问 127.0.0.1:9999/sayhi

# 运行环境设置
spring:profiles:active: test

image.png
这次访问 127.0.0.1:11111/sayhi

# 运行环境设置
spring:profiles:active: prod

image.png

五 . 简化日志的小技巧 - lombok

我们在 com.example.demo 包底下新建一个 StudentController 类
然后编写代码

package com.example.demo;import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;@RestController
public class StudentController {// 1. 得到日志对象private static Logger logger = LoggerFactory.getLogger(StudentController.class);@RequestMapping("/hi")public String sayHi() {// 2. 使用日志对象提供的方法进行日志打印logger.trace("Hi,I am trace.");logger.debug("Hi,I am debug.");return "Hi,Spring Boot.";}
}

image.png
但是每次这样写 , 我们还觉得怪麻烦的
那我们的 Spring Boot 还是可以解决这个问题的
这就需要我们使用额外的库 - lombok
我们之前不想写 Getter Setter 方法 , 只要在上面加上 @Getter @Setter 注解 , 甚至直接加一个 @Data 注解即可
等到日志这里 , 我们发现唯一不同的 ,就是图片里圈出来那部分 , lombok 发现了 , 只有类型不同 , 那么我们只需要拿到当前类的类型呗 , 那我就通过一个注解帮你完成 , 注解内部就是我们图片里的这句代码 , lombok 自动帮我们获取类型了
那怎么使用 lombok 来更简单的输出呢 ?

5.1 lombok 的使用

  1. 添加 lombok 框架支持。
  2. 使用 @slf4j 注解输出日志。
package com.example.demo;import lombok.extern.slf4j.Slf4j;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;// 1. 引入 lombok 依赖
@Slf4j
@RestController
public class StudentController {@RequestMapping("/hi")public String sayHi() {// 2. 使用日志对象提供的方法进行日志打印log.debug("Hi,I am debug.");return "Hi,Spring Boot.";}
}

image.png


有的同学可能调用不出来 lombok , 比如这样
image.png
只需要添加 lombok 的依赖即可
右键 -> Generate
image.png
选择 Dependency
image.png
搜索 lombok , 选择第二个
image.png
这样 lombok 依赖就自己添加进去了
前提是 IDEA 版本是 2021.3.2+ , 其他版本我们也可以选择装一个插件 : EditStarters 实现依赖引入
image.png
image.png
image.png
这个页面似曾相识
image.png
这样依赖就添加进去了 , 记得手动刷新一下

5.2 lombok 的原理

image.png
image.png
image.png
image.png
image.png
image.png
image.png
实际上 , 原理就是这样
image.png
lombok 在编译期间就开始干活了 , 这样对于 JVM 来说是感知不到的 , 他就知道我们传过来的代码里面已经有日志对象了

5.3 lombok 更多注解说明

基本注解 :

注解作用
@Getter自动添加 getter 方法
@Setter自动添加 setter 方法
@ToString自动添加 toString 方法
@EqualsAndHashCode自动添加 equals 和 hashCode 方法
@NoArgsConstructor自动添加 无参构造 方法
@AllArgsConstructor自动添加 全属性的构造方法 方法 , 顺序按照属性的定义顺序
@NonNull属性设置成不能为 null
@RequiredArgsConstructor⾃动添加必需属性的构造方法 , final + @NonNull 的属性为必需

组合注解 :

注解作用
@Data@Getter + @Setter + @ToString +
@EqualsAndHashCode +
@RequiredArgsConstructor +
@NoArgsConstructor

日志注解 :

注解作用
@Slf4j添加⼀个名为 log 的日志,使用 slf4j

总结

日志是程序中的重要组成部分,试用日志可以快速的发现和定位问题,Spring Boot 提供了日志框架 , 默认情况下使用的是 info 日志级别将日志输出到控制台的,我们可以通过 lombok 提供的 @Slf4j 注解和 log 对象快速的打印自定义日志,⽇日志包含 6 个级别:

  • trace:微量,少许的意思,级别最低;
  • info:普通的打印信息;
  • debug:需要调试时候的关键信息打印;
  • warn:警告,不影响使用,但需要注意的问题;
  • error:错误信息,级别较高的错误日志信息;
  • fatal:致命的,因为代码异常导致程序退出执行的事件。

日志级别依次提升 , 而日志级别越高,收到的日志信息也就越少,我们可以通过配置日志的保存名称或保存目录来将日志永久地保存下来。


至此 , Spring Boot 的日志文件就分享完毕 , 给个三连来救救小猫
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/30002.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

flutter 手写日历组件

先看效果 直接上代码 calendar_popup_view.dart import package:flutter/material.dart; import package:intl/intl.dart;import custom_calendar.dart; import hotel_app_theme.dart;class CalendarPopupView extends StatefulWidget {const CalendarPopupView({required th…

【【萌新的STM32 学习-6】】

萌新的STM32 学习-6 BSP 文件夹,用于存放正点原子提供的板级支持包驱动代码,如:LED、蜂鸣器、按键等。 本章我们暂时用不到该文件夹,不过可以先建好备用。 CMSIS 文件夹,用于存放 CMSIS 底层代码(ARM 和 ST…

深度学习之用PyTorch实现逻辑回归

0.1 学习视频源于:b站:刘二大人《PyTorch深度学习实践》 0.2 本章内容为自主学习总结内容,若有错误欢迎指正! 代码(类比线性回归): # 调用库 import torch import torch.nn.functional as F#…

HDFS小文件解决方案---archive归档文件命令

小文件解决方案 背景Archive概述创建archive查看归档文件查看归档之后的样子查看归档文件之前的样子 提取archivearchive注意事项 背景 hdfs并不擅长存储小文件,因为每个文件最少一个block,每个block的元数据都会在namenode占用内存,如果存在…

Linux驱动之设备树添加蜂鸣器驱动

目录 一、蜂鸣器简介 二、硬件原理分析 三、蜂鸣器驱动原理 四、开发环境 五、修改设备树文件 1、添加 pinctrl 节点 2、添加 BEEP 设备节点 3、检查 PIN 是否被其他外设使用 六、蜂鸣器驱动程序编写 七、测试程序编写 八、运行验证 在 I.MX6U-ALPHA 开发板上有一个有源…

一种水文水利行业满管非满管双声道流量计安装调试

供电电源 用户应该特别注意:若是交流(AC220V)供电的主机插入直流电源,或者直流(DC24V)供电的主机接入AC220V电源,就会把流量计烧毁。 普通主机(包括固定式主机、盘装式主机&#x…

前沿分享-无创检测血糖RF波

非侵入性血糖仪,利用射频 (RF) 波连续测量血液中的葡萄糖水平。利用射频波技术连续实时监测血液中的葡萄糖水平,使用的辐射要比手机少得多。 大概原理是血液中的葡萄糖是具有介电特性,一般来说就是介电常数。 电磁波波幅的衰减反映了介质对电…

火车头采集器AI伪原创【php源码】

大家好,本文将围绕python作业提交什么文件展开说明,python123怎么提交作业是一个很多人都想弄明白的事情,想搞清楚python期末作业程序需要先了解以下几个事情。 火车头采集ai伪原创插件截图: I have a python project, whose fold…

FFmpeg常见命令行(二):FFmpeg转封装

前言 在Android音视频开发中,网上知识点过于零碎,自学起来难度非常大,不过音视频大牛Jhuster提出了《Android 音视频从入门到提高 - 任务列表》。本文是Android音视频任务列表的其中一个, 对应的要学习的内容是:如何使…

C# 2048小游戏核心算法

文章目录 01.程序结构划分02.去零03.合并04.上移05.下移/左移/右移&#xff0c;只是取数据的方向不同06.提高可读性 01.程序结构划分 02.去零 有序向量“唯一化”的思路。 /// <summary>/// 去零/// </summary>/// <param name"row">对于一行或一…

Clash 意外退出后 chrome / google 谷歌 浏览器无法连接互联网

解决方案&#xff1a; 以管理员模式打开命令行&#xff0c;输入&#xff1a;netsh winsock reset &#xff0c;然后重启电脑 如果还不行的话&#xff0c; 在 chromevs中选中 设置>隐私和安全>安全>使用安全 dns> 使用您当前的服务提供商 即可

数据结构和算法——哈希查找冲突处理方法(开放地址法-线性探测、平方探测、双散列探测、再散列,分离链接法)

目录 开放地址法&#xff08;Open Addressing&#xff09; 线性探测&#xff08;Linear Probing&#xff09; 散列表查找性能分析 平方探测&#xff08;Quadratic Probing&#xff09; 定理 平方探测法的查找与插入 双散列探测法&#xff08;Double Hashing&#xff09…

分布式 - 消息队列Kafka:Kafka生产者发送消息的3种方式

文章目录 1. Kafka 生产者2. kafaka 命令行操作3. Kafka 生产者发送消息流程4. Kafka 生产者发送消息的3种方式1. 发送即忘记2. 同步发送3. 异步发送 5. Kafka 消息对象 ProducerRecord 1. Kafka 生产者 Kafka 生产者是指使用 Apache Kafka 消息系统的应用程序&#xff0c;它们…

Pytorch深度学习-----神经网络模型的保存与加载(VGG16模型)

系列文章目录 PyTorch深度学习——Anaconda和PyTorch安装 Pytorch深度学习-----数据模块Dataset类 Pytorch深度学习------TensorBoard的使用 Pytorch深度学习------Torchvision中Transforms的使用&#xff08;ToTensor&#xff0c;Normalize&#xff0c;Resize &#xff0c;Co…

Git介绍及常用命令详解

一、Git的概述 Git是一个分布式版本控制工具&#xff0c;通常用来对软件开发过程中的源代码文件进行管理。 Git 会跟踪我们对文件所做的更改&#xff0c;因此我们可以记录已完成的工作&#xff0c;并且可以在需要时恢复到特定或以前的版本。Git 还使多人协作变得更加容易&…

Linux系统中的自旋锁(两幅图清晰说明)

总结&#xff1a; 多CPU下的自旋锁采取的是忙等待&#xff08;原地打转&#xff09;机制&#xff0c;虽然忙等待的线程占用了它所在的cpu&#xff0c;但其他线程仍可放到其他CPU上执行。所以自旋锁上锁和解锁之间的临界区代码要尽量的短&#xff0c;最好不要超过5行&#xff0c…

jenkins流水线

1.拉取代码 https://gitee.com/Wjc_project/yygh-parent.git2、项目编译 mvn clean package -Dmaven.test.skiptrue ls hospital-manage/target3、构建镜像 ls hospital-manage/target docker build -t hospital-manage:latest -f hospital-manage/Dockerfile ./hospital-ma…

AWD攻防学习总结(草稿状态,待陆续补充)

AWD攻防学习总结 防守端1、修改密码2、备份网站3、备份数据库4、部署WAF5、部署文件监控脚本6、部署流量监控脚本/工具7、D盾扫描&#xff0c;删除预留webshell8、代码审计&#xff0c;seay/fortify扫描&#xff0c;漏洞修复及利用9、时刻关注流量和积分信息&#xff0c;掉分时…

业绩难言乐观,皓泽电子撤回上市申请,小米等为其关联方

撰稿|行星 来源|贝多财经 8月8日&#xff0c;深圳证券交易所披露的信息显示&#xff0c;由于河南皓泽电子股份有限公司&#xff08;下称“皓泽电子”&#xff09;及其保荐人主动要求撤回申请文件&#xff0c;深交所终止了皓泽电子的发行注册程序。 据此前招股书披露&#xff…

python爬虫实战(1)--爬取新闻数据

想要每天看到新闻数据又不想占用太多时间去整理&#xff0c;萌生自己抓取新闻网站的想法。 1. 准备工作 使用python语言可以快速实现&#xff0c;调用BeautifulSoup包里面的方法 安装BeautifulSoup pip install BeautifulSoup完成以后引入项目 2. 开发 定义请求头&#xf…