认清现实,放弃幻想,准备斗争
通过日志查看程序的运行过程,运行信息,异常信息等
日志记录器(Logger)的行为是分等级的。如下表所示:
分为:TRACE, DEBUG, INFO, WARN, ERROR, ALL 和 OFF
默认情况下,spring boot从控制台打印出来的日志级别只有INFO及以上级别,可以配置日志级别
# 设置日志级别
logging:
level:
root: ERROR
这种方式能将ERROR级别以及以上级别的日志输出到控制台上,其他级别将不会输出
先删除前面在application.yml中的日志级别配置
resources 中创建 logback-spring.xml (默认日志文件的名字)
- "1.0" encoding="UTF-8"?>
- <configuration>
-
- configuration>
将以下日志输出到任意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);
- }
<configuration>configuration>
每个logger都关联到logger上下文,默认上下文名称为“default”。但可以使用
<contextName>atguiguSrbcontextName>
通过
- <property name="log.path" value="D:/project/finance/srb_log/core" />
-
- <property name="CONSOLE_LOG_PATTERN"
- value="%yellow(%date{yyyy-MM-dd HH:mm:ss}) %highlight([%-5level]) %green(%logger) %msg%n"/>
-
- <property name="FILE_LOG_PATTERN"
- value="%date{yyyy-MM-dd HH:mm:ss} [%-5level] %thread %file:%line %logger %msg%n" />
-
- <property name="ENCODING"
- value="UTF-8" />
- <appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">
- <encoder>
- <pattern>${CONSOLE_LOG_PATTERN}pattern>
- <charset>${ENCODING}charset>
- encoder>
- appender>
- <appender name="FILE" class="ch.qos.logback.core.FileAppender">
- <file>${log.path}/log.logfile>
- <append>trueappend>
- <encoder>
- <pattern>${FILE_LOG_PATTERN}pattern>
- <charset>${ENCODING}charset>
- encoder>
- appender>
name:用来指定受此logger约束的某一个包或者具体的某一个类
level:用来设置打印级别,大小写无关:TRACE, DEBUG, INFO, WARN, ERROR, ALL 和 OFF。默认继承上级的级别
- <logger name="com.atguigu" level="INFO">
- <appender-ref ref="CONSOLE" />
- <appender-ref ref="FILE" />
- logger>
在一个基于Spring boot开发的项目里,常常需要有多套环境的配置:开发,测试以及产品。使用springProfile 可以分别配置开发(dev),测试(test)以及生产(prod)等不同的环境
- <springProfile name="dev,test">
- <logger name="com.atguigu" level="INFO">
- <appender-ref ref="CONSOLE" />
- logger>
- springProfile>
-
- <springProfile name="prod">
- <logger name="com.atguigu" level="ERROR">
- <appender-ref ref="CONSOLE" />
- <appender-ref ref="FILE" />
- logger>
- springProfile>
问题:生产环境下,如果系统长时间运行,那么日志文件会变得越来越大,系统读取和写入日志的时间会越来越慢,严重的情况会耗尽系统内存,导致系统宕机。
解决方案:可以设置滚动日志。
RollingFileAppender是Appender的另一个实现,表示滚动记录文件,先将日志记录到指定文件,当符合某个条件时,将旧日志备份到其他文件
TimeBasedRollingPolicy:最常用的滚动策略,根据时间来制定滚动策略。
- <appender name="ROLLING_FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
-
-
- <file>${log.path}/log-rolling.logfile>
- <encoder>
- <pattern>${FILE_LOG_PATTERN}pattern>
- <charset>${ENCODING}charset>
- encoder>
-
-
-
- <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
-
- <fileNamePattern>${log.path}/info/log-rolling-%d{yyyy-MM-dd}.logfileNamePattern>
-
- <maxHistory>15maxHistory>
- rollingPolicy>
-
- appender>
放在
注意:修改日志文件名 此时
- <timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
- <maxFileSize>1KBmaxFileSize>
- timeBasedFileNamingAndTriggeringPolicy>
- "1.0" encoding="UTF-8"?>
- <configuration>
-
- <contextName>atguiguSrbcontextName>
-
-
- <property name="log.path" value="D:/project/test/srb_log/core" />
-
-
-
-
-
-
-
- <property name="CONSOLE_LOG_PATTERN"
- value="%yellow(%date{yyyy-MM-dd HH:mm:ss}) %highlight([%-5level]) %green(%logger) %msg%n"/>
-
-
- <property name="FILE_LOG_PATTERN"
- value="%date{yyyy-MM-dd HH:mm:ss} [%-5level] %thread %file:%line %logger %msg%n" />
-
-
- <property name="ENCODING"
- value="UTF-8" />
-
-
- <appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">
- <encoder>
- <pattern>${CONSOLE_LOG_PATTERN}pattern>
- <charset>${ENCODING}charset>
- encoder>
- appender>
-
-
- <appender name="FILE" class="ch.qos.logback.core.FileAppender">
- <file>${log.path}/log.logfile>
- <append>trueappend>
- <encoder>
- <pattern>${FILE_LOG_PATTERN}pattern>
- <charset>${ENCODING}charset>
- encoder>
- appender>
-
- <appender name="ROLLING_FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
-
-
- <file>${log.path}/log-rolling.logfile>
- <encoder>
- <pattern>${FILE_LOG_PATTERN}pattern>
- <charset>${ENCODING}charset>
- encoder>
-
-
-
- <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
-
- <fileNamePattern>${log.path}/info/log-rolling-%d{yyyy-MM-dd}.%i.logfileNamePattern>
-
- <maxHistory>15maxHistory>
-
- <timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
- <maxFileSize>1KBmaxFileSize>
- timeBasedFileNamingAndTriggeringPolicy>
- rollingPolicy>
-
- appender>
-
-
-
-
-
-
-
-
- <springProfile name="dev,test">
- <logger name="com.atguigu" level="INFO">
- <appender-ref ref="CONSOLE" />
- logger>
- springProfile>
-
-
- <springProfile name="prod">
- <logger name="com.atguigu" level="ERROR">
- <appender-ref ref="CONSOLE" />
- <appender-ref ref="ROLLING_FILE" />
- logger>
- springProfile>
- configuration>