方便甩锅…
写代码初期根本没有记录日志的概念,无非就是等报错,然后在哪里写个日志输出,找一下报错源头,或者某个方法用时过程,输出日志查看一下是那段代码用时过久。再往后,入职时间久一点,日志也越用越多,但方法仍是笨拙,大部分情况都是在ServiceImpl类里private一个log,然后在try catch中记录下error信息,但一旦出现问题,需要追溯有可能在日志中根本找不到,或者tomcat catalina.out文件过大,根本无法定位具体报错节点。
因此最先研究的是日志框架,搭建完成后会输出一定大小的日志文件,放于指定目录,设置时效,仅保留一段时间的,并不会无限增大,占用服务器磁盘空间,这样查找日志的时候,我只需定位到天,之后根据时间精确找到当天我所需要的日志文件,大大节省了时间,提高效率。
日志框架
平时我会在微信里面关注一些公众号,吃早饭的时间会看一看有没有有趣的文章和知识点,也是受这篇文章启发,才知道日志可以这么写,有兴趣可以去看一下,或者搜索最新的,毕竟也是一年前的文章了。
个人搭建的是Spring Boot项目,目前使用的是slf4j+logback,直接上logback.xml,是项目现在的配置,info级别的,这样前端请求参数和返回数据都记录下来,一目了然。
<?xml version="1.0" encoding="UTF-8"?>
<configuration>
<!-- 格式化输出:%date表示日期,%thread表示线程名,%-5level:级别从左显示5个字符宽度 %msg:日志消息,%n是换行符-->
<property name="LOG_PATTERN" value="%-5level %date{HH:mm:ss.SSS} [%thread] %logger{36} - %msg%n" />
<!-- 定义日志存储的路径,不要配置相对路径 -->
<property name="FILE_PATH" value="/mnt/backup/logs/%d{yyyyMMdd}/nc.%d{yyyy-MM-dd}.%i.log" />
<!-- 控制台输出日志 -->
<appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">
<encoder>
<!-- 按照上面配置的LOG_PATTERN来打印日志 -->
<pattern>${LOG_PATTERN}</pattern>
</encoder>
</appender>
<!--每天生成一个日志文件,保存15天的日志文件。rollingFile是用来切分文件的 -->
<appender name="FILE" 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>90</maxHistory>
<timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
<!-- 日志文件的最大大小 -->
<maxFileSize>10MB</maxFileSize>
</timeBasedFileNamingAndTriggeringPolicy>
</rollingPolicy>
<encoder>
<pattern>${LOG_PATTERN}</pattern>
</encoder>
</appender>
<!-- project default level -->
<logger name="src" level="INFO" /&