Spring日志的作用:
1.定位和发现问题
2.系统监控
3.数据采集
4.日志审计
打印日志步骤:
1.定义日志对象2.打印日志
@RestController
public class LoggerController {
private static Logger logger= LoggerFactory.getLogger(LoggerController.class);
@PostConstruct
public void print(){
System.out.println("打印日志");
logger.info("日志框架****************88");
}
}
其显示地方与平常打印的地方有很大差别
上述红色字就代表了其的具体信息,日志对象的名称,可能为缩写。通常情况下,是当前类
Spring 默认的日志级别是info
可以在配置中去控制日志级别
门面模式(外观模式)
slf4j是门面模式的典型的应用.
日志框架: SLF4J
他不是一个真实的日志框架,只是一个日志框架的代表(门面模式)框架里面的具体内容是由log4j/log4j2/logback/jul实现的。
SLF4J提供了一个简单的、统一的API,用于在Java应用程序中进行日志记录。它允许开发人员使用统一的代码编写日志记录语句,而不需要关心底层日志框架的具体实现。SLF4J充当了一个门面(Facade),隐藏了底层日志框架(如Logback、Log4j、java.util.logging等)的细节,使得开发人员可以在不改变代码的情况下轻松地切换和配置不同的日志实现。
SLF4J的设计符合门面模式的核心思想:提供一个简单的接口,隐藏底层复杂性。通过SLF4J,开发人员可以在应用程序中使用统一的日志API,而不需要关心具体的日志实现,这样就降低了应用程序的耦合度,并且使得日志记录变得更加灵活和易于管理。因此,SLF4J被认为是门面模式在Java日志记录领域的典型应用。
日志持久化
数据保存在数据库中,是一种持久化的方式
曰志保存在文件中,也是一种持久化的方式
日志保存到文件中的话可以用相对路径,也可以使用绝对路径
name既可以设置路径,又可以设置名称path只能设置路径,默认名称是: spring.log
如果二者同时存在, path 就失效了
name的优先级要高于path
logging:
file:
# name: logger/ioc.log
path: logger1
日志文件分割的名称定义规则日志最大文件
logging:
logback:
rollingpolicy:
max-file-size: 1KB
不是达到1KB就立刻进行分割的以行来分割,不是以字符分割的
企业中,通常日志分割大小为200M或者500M
修改控制台日志格式
logging:
pattern:
console: "%d{HH : mm : ss.SSS} %c %H %L[%thread]%m%n"
修改日志格式
logging:
pattern:
file: "%d{HH : mm : ss.SSS} %c %H %L [%thread] %m%n"
加上@slfj4注解
在类中打印日志不用重复写写log对象的创建,之后会自动进行创建一个log对象来书写日志