Springboot之日志(一)

日志记录是软件开发中的一个重要主题,特别是当您需要分析生产环境中的bug和其他意外事件时。实现日志记录通常很简单。但正如你可能经历过的,日志要比看起来复杂得多。

日志分类

作为一名经验丰富的开发人员,应该了解可用的不同日志记录框架、常见陷阱和最佳实践,当然还应该了解在常见部署场景中使用的日志文件的类型。

应用程序日志

大多数开发人员在谈到日志记录时会想到这个日志。原因很简单。它们的应用程序生成此日志。它包含应用程序编写的各种错误消息、警告或其他事件。这些消息可以提供连接到特定用例的逻辑、高级信息。应用程序日志可能是本文中提到的最重要的日志类型,因为您已经对其进行了完全控制。每个日志消息需要提供有用的信息,帮助您了解应用程序的行为。典型的例子是:

  1. 在用例中发生的异常的堆栈跟踪。
  2. 关于外部系统慢响应时间的警告消息。
  3. 一个用例被触发或完成的信息。

Web或应用服务器的日志

大多数企业应用程序被部署到web服务器(例如,Apache Tomcat)或应用服务器(例如,Wildfly或WebSphere.ty)。他们的日志文件为您提供有关技术问题和服务器当前状态的信息。每个服务器的配置和功能不同,我不会在本文中详细解释它们。但是请确保检查服务器的文档并相应地配置它。从服务器获取正确的信息可以在及时识别潜在问题和服务器停机之间产生差异。

垃圾收集器日志

垃圾回收器提供自动内存管理。它跟踪在JVM内实例化的所有对象,并移除不再使用的对象。这是一项非常复杂的任务,有几种不同的垃圾收集器实现可用。一般来说,Java中的垃圾回收过程非常高效。这是非常有效的,有很多应用程序使用标准配置的默认实现。但是,如果应用程序必须处理高负载或使用许多复杂的对象结构,应用程序的性能可能会随着时间而降低。当垃圾收集器需要花费越来越多的时间来管理可用内存时,这种情况经常发生。垃圾收集器日志为您提供分析所有垃圾收集器活动的必要信息。默认情况下,垃圾收集器日志将被停用。您需要用一组命令行属性激活它。

操作系统所写的日志

作为Java开发人员,您很可能永远不会自己编写这些日志。但是,您的操作系统将某些事件写入这些日志。作为部署的一部分的其他应用程序也可以这样做。因此,系统日志是一个了解外部事件的好地方。如果你在Windows上运行你的应用程序,这是事件日志。在Linux上,您应该知道系统日志服务及其后继者。

springboot日志

程序日志

对于一个应用程序来说日志记录是必不可少的一部分。线上问题追踪,基于日志的业务逻辑统计分析等都离不日志。

Slf4j

slf4j 的全称是 Simple Loging Facade For Java,即它仅仅是一个为 Java 程序提供日志输出的统一接
口,并不是一个具体的日志实现方案,
就比如 JDBC 一样,只是一种规则而已。所以单独的 slf4j 是不
能工作的,必须搭配其他具体的日志实现方案,比如 apache 的 org.apache.log4j.Logger,jdk 自带
的 java.util.logging.Logger 等。

Log4j

Log4j 是 Apache 的一个开源项目,通过使用 Log4j,我们可以控制日志信息输送的目的地是控制台、
文件、GUI 组件,甚至是套接口服务器、NT 的事件记录器、UNIX Syslog 守护进程等;我们也可以控
制每一条日志的输出格式;通过定义每一条日志信息的级别,我们能够更加细致地控制日志的生成过程。

Log4j 由三个重要的组成构成:日志记录器(Loggers),输出端(Appenders)和日志格式化器(Layout)。

  1. Logger:控制要启用或禁用哪些日志记录语句,并对日志信息进行级别限制
  2. Appenders : 指定了日志将打印到控制台还是文件中
  3. Layout : 控制日志信息的显示格式

Log4j 中将要输出的 Log 信息定义了 5 种级别,依次为 DEBUG、INFO、WARN、ERROR 和 FATAL,
当输出时,只有级别高过配置中规定的 级别的信息才能真正的输出,这样就很方便的来配置不同情况
下要输出的内容,而不需要更改代码。

LogBack

简单地说,Logback 是一个 Java 领域的日志框架。它被认为是 Log4J 的继承人。Sprongboot默认使用这个日志。

Logback 主要由三个模块组成:logback-core,logback-classic。logback-access
logback-core 是其它模块的基础设施,其它模块基于它构建,显然,logback-core 提供了一些关键的通用机制。
logback-classic 的地位和作用等同于 Log4J,它也被认为是 Log4J 的一个改进版,并且它实现了简单日志门面 SLF4J;
logback-access 主要作为一个与 Servlet 容器交互的模块,比如说 tomcat 或者 jetty,提供一些与HTTP 访问相关的功能。

优点

同样的代码路径,Logback 执行更快
更充分的测试
原生实现了 SLF4J API(Log4J 还需要有一个中间转换层)
内容更丰富的文档
支持 XML 或者 Groovy 方式配置
配置文件自动热加载
从 IO 错误中优雅恢复
自动删除日志归档
自动压缩日志成为归档文件
支持 Prudent 模式,使多个 JVM 进程能记录同一个日志文件
支持配置文件中加入条件判断来适应不同的环境
更强大的过滤器
支持 SiftingAppender(可筛选 Appender)
异常栈信息带有包信息

操作日志

记录操作日志是web系统做安全审计和系统维护的重要手段,这里总结笔者在用java和python开发web系统过程中总结出来的、具有普遍意义的方法。

系统的操作日志主要通过代码实现的,将操作记录到数据库中,java中一般的实现方式就是通过aop实现的。主要用到注解、反射、aop 技术来实现。后面我会实现这个用注解的方式来实现这个操作日志的记录。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值