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

SpringBoot 日志文件

(一)日志文件有什么用?

除了发现和定位问题之外,我们还可以通过日志实现以下功能:

  • 记录用户登录日志,以便分析用户是正常登录还是恶意破解用户。

  • 记录系统的操作日志,以便数据恢复和定位操作 。

  • 记录程序的执行时间,以便为以后优化程序提供数据支持。

以上内容就是 Spring Boot 输出的控制台日志信息。通过上述日志信息我们能发现以下 3个问题:

  • Spring Boot 内置了日志框架 (不然也输出不了日志)。

  • 默认情况下,输出的日志并非是开发者定义和打印的,那开发者怎么在程序中自定义打印日志呢?

  • 日志默认是打在控制台上的,而控制台的日志是不能被保存的,那么怎么把日志永久的保存下来呢?

同样是输出到控制台,为什么不使用sout,而要使用日志呢?

① 日志

(二)日志基础使用

注意:我们使用的是Logger 对象是属于 org.slf4j 包下的
日志工厂需要将每个类的类型传递进去,这样我们才知道日志的归属类,才能更方便定位问题。
Logger logger = LoggerFactory.getLogger(类名.class);

(三)日志相关基础概念

(1)日志说明

(2)日志级别

  • trace :微量,少许的意思,级别最低

  • debug :需要调试时候的关键信息打印

  • info :普通的打印信息 (默认日志级别)

  • warn :警告,不影响使用,但需要注意的问题

  • error :错误信息,级别较高的错误日志信息

  • fatal :致命的,因为代码异常导致程序退出执行的事件

(3)日志级别的设置

我们可以通过设置日志级别来让其只显示 自己想要的日志,默认的日志级别的info
越往上接收到的消息就越少如设置了 warn 就只能收到 warn、error、fatal 级别的日志了。

日志级别配置只需要在配置文件中设置“logging.level”配置项即可,如下所示:

logging:level:root: error

(四)日志持久化

日志不会文件过大,超过文件默认大小的时候,会自动再创建一个文件.

两种方案:

① 设置日志的保存目录

②设置日志的保存文件名

# ①设置日志文件的目录
logging:file:path: D:\\logs
# ②设置日志文件的文件名
#    如果只设置文件名,那么会放在项目路径下
#    可以设置路径+文件名
logging:file:name: D:\\logs\\springBoot0217.log

(五)更简单的日志输出:lombok

每次都使用 LoggerFactory.getLogger(xxx.class)很繁琐,且每个类都添加一遍,很麻烦,使用 lombok 可以来更简单的输出。
1.添加 lombok 框架支持
2.使用 @slf4i 注解输出日志
@RestController
@RequestMapping("/p")
@Slf4j //使用这个注解
public class PersonController {@RequestMapping("/log")public void loggerTest() {log.error("------ error ------");}
}

原理:

其实lombok,其实实际上没有改动什么,只是简化了我们写代码的方式

其实编译后的目标文件夹,内容还是之前麻烦的代码,而lombok改变的只是我们写代码的方式

(六)旧的项目添加新依赖:editstarters

① 安装插件

② 在pox.xml中右键 或者 alt +insert

③ 选择这个插件

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

相关文章:

  • SQL71 检索供应商名称
  • 02:入门篇 - 漫谈 CTK
  • SpringBoot常用注解
  • RBAC权限模型
  • 【郭东白架构课 模块一:生存法则】07|法则三:架构师如何找到自己的商业模式?
  • STM32 - 看门狗
  • Redis集群搭建
  • 车载基础软件——AUTOSAR AP典型应用案例
  • 消息中间件----内存数据库 Redis7(第3章 Redis 命令)
  • react-03-react-router-dom-路由
  • 2自由度悬架LQR控制
  • C语言返回类型为指针的一些经典题目(下)
  • OpenAI 官方api 阅读笔记
  • 微服务项目【分布式锁】
  • JavaWeb5-线程常用属性
  • JVM调优及垃圾回收GC
  • JAVA练习53-打乱数组
  • 基于RK3588的嵌入式linux系统开发(三)——Uboot镜像文件合成
  • wireshark抓包后通过工具分包
  • 举个栗子~Tableau 技巧(251):统一多个工作表的坐标轴范围
  • Centos7 调整磁盘空间
  • 小菜版考试系统——“C”
  • Twitter被封号了?最详细的申诉教程在此
  • Docker 安装配置
  • 死锁检测组件-设想
  • 线程池的使用
  • 字节码指令
  • TLS/SSL证书彻底扫盲
  • WGCNA | 值得你深入学习的生信分析方法!~(网状分析-第五步-高级可视化)
  • try catch finally执行顺序