Logback日志
一、Logback日志
1、什么是日志
通过日志查看程序的运行过程,运行信息,异常信息等
2、日志级别
日志记录器(Logger)的行为是分等级的。如下表所示:
分为:TRACE, DEBUG, INFO, WARN, ERROR, ALL 和 OFF
默认情况下,spring boot从控制台打印出来的日志级别只有INFO及以上级别,可以配置日志级别
# 设置日志级别 logging: level: root: ERROR
这种方式能将ERROR级别以及以上级别的日志输出到控制台上,其他级别将不会输出
3、创建日志文件
SpringBoot内部使用Logback作为日志实现的框架。
先删除前面在application.yml中的日志级别配置
resources 中创建 logback-spring.xml (默认日志文件的名字)
<?xml version="1.0" encoding="UTF-8"?> <configuration> </configuration>
4、创建测试日志输出
将以下日志输出到任意controller的方法中即可,例如list方法中
@ApiOperation("积分等级列表") @GetMapping("/list") public R listAll(){ log.info("hi i'm helen"); log.warn("warning!!!"); log.error("it's a error"); List<IntegralGrade> list = integrationService.list(); return R.ok().data("list", list); }
二、基本配置说明
1、configuration
日志配置的根节点
<configuration></configuration>
2、contextName
每个logger都关联到logger上下文,默认上下文名称为"default"。但可以使用
<contextName>hguo</contextName>
3、property
通过
<!-- 日志的输出目录 --> <property name="log.path" value="D:/project/finance/srb_log/core" /> <!--控制台日志格式:彩色日志 magenta:洋红 boldMagenta:粗红 cyan:青色 white:白色 magenta:洋红 --> <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" />
4、appender
控制台日志配置
<!-- 控制台日志 --> <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.log</file> <append>true</append> <encoder> <pattern>${FILE_LOG_PATTERN}</pattern> <charset>${ENCODING}</charset> </encoder> </appender>
5、logger
name:用来指定受此logger约束的某一个包或者具体的某一个类
level:用来设置打印级别,大小写无关:TRACE, DEBUG, INFO, WARN, ERROR, ALL 和 OFF。默认继承上级的级别
<!-- 日志记录器 --> <logger name="com.hguo" level="INFO"> <appender-ref ref="CONSOLE" /> <appender-ref ref="FILE" /> </logger>
6、测试
测试日志记录的控制台输出、文件输出、以及日志级别
三、多环境配置
springProfile
在一个基于Spring boot开发的项目里,常常需要有多套环境的配置:开发,测试以及产品。使用springProfile 可以分别配置开发(dev),测试(test)以及生产(prod)等不同的环境
<!-- 开发环境和测试环境 --> <springProfile name="dev,test"> <logger name="com.hguo" level="INFO"> <appender-ref ref="CONSOLE" /> </logger> </springProfile> <!-- 生产环境 --> <springProfile name="prod"> <logger name="com.hguo" level="ERROR"> <appender-ref ref="CONSOLE" /> <appender-ref ref="FILE" /> </logger> </springProfile>
四、滚动日志
问题:生产环境下,如果系统长时间运行,那么日志文件会变得越来越大,系统读取和写入日志的时间会越来越慢,严重的情况会耗尽系统内存,导致系统宕机。
解决方案:可以设置滚动日志。
1、设置时间滚动策略
RollingFileAppender是Appender的另一个实现,表示滚动记录文件,先将日志记录到指定文件,当符合某个条件时,将旧日志备份到其他文件
TimeBasedRollingPolicy:最常用的滚动策略,根据时间来制定滚动策略。
<appender name="ROLLING_FILE" class="ch.qos.logback.core.rolling.RollingFileAppender"> <!-- 要区别于其他的appender中的文件名字 --> <file>${log.path}/log-rolling.log</file> <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}.log</fileNamePattern> <!--归档日志文件保留的最大数量--> <maxHistory>15</maxHistory> </rollingPolicy> </appender>
2、设置触发滚动时机
放在
注意:修改日志文件名 此时
<timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP"> <maxFileSize>1KB</maxFileSize> </timeBasedFileNamingAndTriggeringPolicy>
五、完整的日志配置文件
<?xml version="1.0" encoding="UTF-8"?> <configuration> <contextName>hguo-srb</contextName> <!-- 日志的输出目录 --> <property name="log.path" value="F:\log\srb_log" /> <!--控制台日志格式:彩色日志--> <!-- magenta:洋红 --> <!-- boldMagenta:粗红--> <!-- cyan:青色 --> <!-- white:白色 --> <!-- magenta:洋红 --> <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}/srb-log.log</file> <append>true</append> <encoder> <pattern>${FILE_LOG_PATTERN}</pattern> <charset>${ENCODING}</charset> </encoder> </appender> <!--滚动日志--> <appender name="ROLLING_FILE" class="ch.qos.logback.core.rolling.RollingFileAppender"> <!-- 要区别于其他的appender中的文件名字 --> <file>${log.path}/log-rolling.log</file> <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}.log</fileNamePattern>--> <!--添加.%i日志间区别--> <fileNamePattern>${log.path}/info/log-rolling-%d{yyyy-MM-dd}.%i.log</fileNamePattern> <!--归档日志文件保留的最大数量--> <maxHistory>15</maxHistory> <!--设置触发滚动时机--> <timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP"> <!--日志文件达到1MB执行策略从新生成一个日志文件且以.%i的标识区分--> <maxFileSize>1MB</maxFileSize> </timeBasedFileNamingAndTriggeringPolicy> </rollingPolicy> </appender> <!-- 日志记录器 --> <!-- com.hguo目录下的日志都归日志记录器管理 level:日志级别 --> <!--<logger name="com.hguo" level="INFO">--> <!--<appender-ref ref="CONSOLE" />--> <!--<appender-ref ref="FILE" />--> <!--</logger>--> <!-- 多环境配置,具体哪个生效看application.properties配置中spring.profiles.active=dev 上面外层日志记录器不用写 --> <!-- 开发环境和测试环境 --> <springProfile name="dev,test"> <logger name="com.hguo" level="DEBUG"> <appender-ref ref="CONSOLE" /> <appender-ref ref="FILE" /> <appender-ref ref="ROLLING_FILE" /> </logger> </springProfile> <!-- 生产环境 --> <springProfile name="prod"> <logger name="com.hguo" level="INFO"> <appender-ref ref="ROLLING_FILE" /> </logger> </springProfile> </configuration>
本文来自博客园,作者:Lz_蚂蚱,转载请注明原文链接:https://www.cnblogs.com/leizia/p/15613860.html
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步