目录
一、Logback日志
1、什么是日志
2、日志级别
3、创建日志文件
4、创建测试日志输出
二、基本配置说明
1、configuration
2、contextName
3、property
4、appender
控制台日志配置
文件日志配置
5、logger
6、测试
三、多环境配置
1、springProfile
四、滚动日志
1、设置时间滚动策略
2、设置触发滚动时机
五、完整的日志配置文件
通过日志查看程序的运行过程,运行信息,异常信息等
日志记录器(Logger)的行为是分等级的。如下表所示:
分为:TRACE, DEBUG, INFO, WARN, ERROR, ALL 和 OFF
默认情况下,spring boot从控制台打印出来的日志级别只有INFO及以上级别,可以配置日志级别
# 设置日志级别
logging:
level:
root: ERROR
这种方式能将ERROR级别以及以上级别的日志输出到控制台上,其他级别将不会输出
spring boot内部使用Logback作为日志实现的框架。
先删除前面在application.yml中的日志级别配置
resources 中创建 logback-spring.xml (默认日志文件的名字)
将以下日志输出到任意controller的方法中即可,例如list方法中
@ApiOperation("积分等级列表")
@GetMapping("/list")
public R listAll(){
log.info("hi i'm helen");
log.warn("warning!!!");
log.error("it's a error");
List list = integrationService.list();
return R.ok().data("list", list);
}
日志配置的根节点
每个logger都关联到logger上下文,默认上下文名称为“default”。但可以使用
BUBAYKASrb
通过
${CONSOLE_LOG_PATTERN}
${ENCODING}
${log.path}/log.log
true
${FILE_LOG_PATTERN}
${ENCODING}
name:用来指定受此logger约束的某一个包或者具体的某一个类
level:用来设置打印级别,大小写无关:TRACE, DEBUG, INFO, WARN, ERROR, ALL 和 OFF。默认继承上级的级别
测试日志记录的控制台输出、文件输出、以及日志级别
在一个基于Spring boot开发的项目里,常常需要有多套环境的配置:开发,测试以及产品。
使用springProfile 可以分别配置开发(dev),测试(test)以及生产(prod)等不同的环境
环境配置基于yml配置文件中
问题:生产环境下,如果系统长时间运行,那么日志文件会变得越来越大,系统读取和写入日志的时间会越来越慢,严重的情况会耗尽系统内存,导致系统宕机。
解决方案:可以设置滚动日志。
设置时间滚动策略:第二天会生成新的日志文件
设置触发滚动时机:单个文件内存大于指定内存,生成新的日志文件
第二天会生成新的日志文件,格式为:log-rolling-2023-07-14.0.log
RollingFileAppender是Appender的另一个实现,表示滚动记录文件,先将日志记录到指定文件,当符合某个条件时,将旧日志备份到其他文件
TimeBasedRollingPolicy:最常用的滚动策略,根据时间来制定滚动策略。
${log.path}/log-rolling.log
${FILE_LOG_PATTERN}
${ENCODING}
${log.path}/info/log-rolling-%d{yyyy-MM-dd}.log
15
设置触发滚动时机:单个文件内存大于指定内存,生成新的日志文件,格式为:log-rolling-2023-07-14.1.log
放在
注意:修改日志文件名 此时
.%i:代表第几个文件。如0.log,1.log,2.log ...
1KB
BUBAYKASrb
${CONSOLE_LOG_PATTERN}
${ENCODING}
${log.path}/log.log
true
${FILE_LOG_PATTERN}
${ENCODING}
${log.path}/log-rolling.log
${FILE_LOG_PATTERN}
${ENCODING}
${log.path}/info/log-rolling-%d{yyyy-MM-dd}.%i.log
15
1KB
直接拿着!!!!!