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

SpringBoot日志

在这里插入图片描述

自定义日志

导入的是slf4j的Logger类
在这里插入图片描述

package app.controller;import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.bind.annotation.GetMapping;@RestController
public class TestController {// 得到日志对象private static Logger logger = LoggerFactory.getLogger(TestController.class);@GetMapping("/log")public void getLog() {logger.info("Customer log");}
}

运行效果
在这里插入图片描述

设置日志级别

日志级别(低->高):trace->debug->info->warn->error
Spring中默认级别: info

root: warn解释:如果SpringBoot中没有为特定的包设置日志级别那么就会使用warn作为默认的日志级别

当设置为warn之后,控制台只会输出大于等于warn级别的日志信息
在这里插入图片描述

日志持久化

日志不会覆盖而是追加的方式添加,日志文件太大的时候会自动分割

# 设置路径
logging:file:path: D:\100.Documents\200.IntelliJIDEA\projects\spring_study\springboot-demo1\src\main\resources\static

在这里插入图片描述

# 设置名称
logging:file:name: springboot.log

在这里插入图片描述

结合lombok使用@Slf4j快速添加日志

这些日志会发现每次在使用的时候需要填写对应的类信息才行

private static Logger logger = LoggerFactory.getLogger(LogController.class);

lombok可以省略掉这一步,哪一个类运行就获取哪一个类的字节码

对比 getLog2 可以更简洁的输出日志

package app.controller;import lombok.extern.slf4j.Slf4j;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;@RestController
@Slf4j
public class LogController {//1.得到日志对象private static Logger logger = LoggerFactory.getLogger(LogController.class);@GetMapping("/log1")public void getLog1() {logger.trace("trace");logger.debug("debug");logger.info("info");logger.warn("warn");logger.error("error");}@GetMapping("/log2")public void getLog2() {log.trace("trace");log.debug("debug");log.info("info");log.warn("warn");log.error("error");}
}

查看字节码文件会发现@Slf4j的运行原理
在这里插入图片描述
说明程序是在编译期自动添加的这一行代码,包括lombok的@Data注解也会自动生成getter、setter、equals、canEqual、hashCode、toString方法都是在编译期生成的代码

http://www.lryc.cn/news/297994.html

相关文章:

  • 006集——where语句进行属性筛选——arcgis
  • 《动手学深度学习(PyTorch版)》笔记8.3
  • 静态时序分析:建立时间分析
  • 深入探究 HTTP 简化:httplib 库介绍
  • ARP欺骗攻击利用之抓取https协议的用户名与密码
  • <s-table>、<a-table>接收后端数据
  • [数学]高斯消元
  • 【Linux】gdb调试与make/makefile工具
  • 使用Arcgis裁剪
  • sheng的学习笔记-网络爬虫scrapy框架
  • Qt PCL学习(三):点云滤波
  • Ainx-V0.2-简单的连接封装与业务绑定
  • 《杨绛传:生活不易,保持优雅》读书摘录
  • ChatGPT在肾脏病学领域的专业准确性评估
  • Centos7.9安装SQLserver2017数据库
  • spring boot和spring cloud项目中配置文件application和bootstrap中的值与对应的配置类绑定处理
  • 每天一个数据分析题(一百五十四)
  • Django从入门到放弃
  • C++中类的6个默认成员函数【构造函数】 【析构函数】
  • 06-Java适配器模式 ( Adapter Pattern )
  • C# CAD交互界面-自定义面板集-添加快捷命令(五)
  • Spring boot集成各种数据源操作数据库
  • K8s环境下rook-v1.13.3部署Ceph-v18.2.1集群
  • 【JavaEE】传输层网络协议
  • 08-Java过滤器模式 ( Filter Pattern )
  • ChatGPT高效提问—prompt常见用法(续篇八)
  • 微软.NET6开发的C#特性——接口和属性
  • 容器基础知识:容器和虚拟化的区别
  • 【Linux】vim的基本操作与配置(下)
  • [office] 图文演示excel怎样给单元格添加下拉列表 #知识分享#经验分享