今天做了个日志记录:

解决问题:

使用了springboot原生自带的一个log框架 

POM添加一个插件(不然使用不了@Slf4j注解):
<dependency> <groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId> <version>1.16.20</version>
<scope>provided</scope> </dependency>
然后就是添加一个lombok插件 (我使用的是IDEA, 其他的IDA可以自行搜索安装方法)

直接按快捷键Ctrl+Alt+s弹出Settings界面







因为我的已经安装了 如果没有安装的话右边会出现一个Install绿色按钮 点击安装即可 ,最后提示一下 安装成功之后一定要重启软件

工具准备好之后就是一个配置了:在项目中的resource下新建一个logback-spring.xml文件
<?xml version="1.0" encoding="UTF-8"?> <configuration scan="true"
scanPeriod="10 seconds"> <contextName>logback</contextName> <!--
格式化输出:%date表示日期,%thread表示线程名,%-5level:级别从左显示5个字符宽度 %msg:日志消息,%n是换行符-->
<property name="LOG_PATTERN" value="%date{HH:mm:ss.SSS} [%thread] %-5level
%logger{36} - %msg%n" /> <!-- 定义日志存储的路径,不要配置相对路径 --> <property name="FILE_PATH"
value="D:/Desktop/log/spring-log.%d{yyyy-MM-dd}.%i.log" /> <!-- 控制台输出日志 -->
<appender name="console" class="ch.qos.logback.core.ConsoleAppender"> <!--
日志级别过滤INFO以下 --> <filter class="ch.qos.logback.classic.filter.ThresholdFilter">
<level>INFO</level> </filter> <encoder> <!-- 按照上面配置的LOG_PATTERN来打印日志 -->
<pattern>${LOG_PATTERN}</pattern> </encoder> </appender>
<!--每天生成一个日志文件,保存30天的日志文件。rollingFile用来切分文件的 --> <appender name="rollingFile"
class="ch.qos.logback.core.rolling.RollingFileAppender"> <rollingPolicy
class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<fileNamePattern>${FILE_PATH}</fileNamePattern> <!-- keep 15 days' worth of
history --> <maxHistory>30</maxHistory> <timeBasedFileNamingAndTriggeringPolicy
class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP"> <!-- 日志文件的最大大小 -->
<maxFileSize>2MB</maxFileSize> </timeBasedFileNamingAndTriggeringPolicy> <!--
超出删除老文件 --> <totalSizeCap>1GB</totalSizeCap> </rollingPolicy> <encoder>
<pattern>${LOG_PATTERN}</pattern> </encoder> </appender> <!-- project default
level --> <logger name="net.sh.rgface.serive" level="ERROR" /> <!-- 日志输出级别 -->
<root level="INFO"> <appender-ref ref="console" /> <appender-ref
ref="rollingFile" /> </root> </configuration>
配置文件有很丰富的扩展,有兴趣可以搜索一下

配置完成之后差不就可以了

最后就是使用:

在使用的类上方添加@Slf4j注解,在使用时log.info()、log.error()、log.warn()等


运行项目之后会发现之前的日志打印在控制台上的是彩色,现在的都是白色了:其实也很好理解,因为配置文件上面输出的级别是INFO,就是说在INFO以上的都会被打印,就像是System.out.print()输出一样,输出的都是白色的。如果需要彩色日志的话可以修改一下logback-spring.xml文件,在<contextName>logback</contextName>下添加:
<!-- 彩色日志 --> <!-- 彩色日志依赖的渲染类 --> <conversionRule conversionWord="clr"
converterClass="org.springframework.boot.logging.logback.ColorConverter" />
<conversionRule conversionWord="wex"
converterClass="org.springframework.boot.logging.logback.WhitespaceThrowableProxyConverter"
/> <conversionRule conversionWord="wEx"
converterClass="org.springframework.boot.logging.logback.ExtendedWhitespaceThrowableProxyConverter"
/> <!-- 彩色日志格式 --> <property name="CONSOLE_LOG_PATTERN"
value="${CONSOLE_LOG_PATTERN:-%clr(%d{yyyy-MM-dd HH:mm:ss.SSS}){faint}
%clr(${LOG_LEVEL_PATTERN:-%5p}) %clr(${PID:- }){magenta} %clr(---){faint}
%clr([%15.15t]){faint} %clr(%-40.40logger{39}){cyan} %clr(:){faint}
%m%n${LOG_EXCEPTION_CONVERSION_WORD:-%wEx}}"/>
注意红色部分
CONSOLE_LOG_PATTERN
修改为:注意修改的位置红色部分
<!-- 控制台输出日志 --> <appender name="console"
class="ch.qos.logback.core.ConsoleAppender"> <!-- 日志级别过滤INFO以下 --> <filter
class="ch.qos.logback.classic.filter.ThresholdFilter"> <level>INFO</level>
</filter> <encoder> <!-- 按照上面配置的LOG_PATTERN来打印日志 --> <pattern>${LOG_PATTERN}
</pattern>//替换为${CONSOLE_LOG_PATTERN} </encoder> </appender>
在运行控制台上没有错就会出现彩色日志了

注:有问题可以评论哦 我看到就会回复,有错误希望指出 谢谢



友情链接
ioDraw流程图
API参考文档
OK工具箱
云服务器优惠
阿里云优惠券
腾讯云优惠券
华为云优惠券
站点信息
问题反馈
邮箱:ixiaoyang8@qq.com
QQ群:637538335
关注微信