Java项目 日志框架+切面,完美记录

方便甩锅…

写代码初期根本没有记录日志的概念,无非就是等报错,然后在哪里写个日志输出,找一下报错源头,或者某个方法用时过程,输出日志查看一下是那段代码用时过久。再往后,入职时间久一点,日志也越用越多,但方法仍是笨拙,大部分情况都是在ServiceImpl类里private一个log,然后在try catch中记录下error信息,但一旦出现问题,需要追溯有可能在日志中根本找不到,或者tomcat catalina.out文件过大,根本无法定位具体报错节点。

因此最先研究的是日志框架,搭建完成后会输出一定大小的日志文件,放于指定目录,设置时效,仅保留一段时间的,并不会无限增大,占用服务器磁盘空间,这样查找日志的时候,我只需定位到天,之后根据时间精确找到当天我所需要的日志文件,大大节省了时间,提高效率。

日志框架

全网最全 Java 日志框架适配方案!还有谁不会?

平时我会在微信里面关注一些公众号,吃早饭的时间会看一看有没有有趣的文章和知识点,也是受这篇文章启发,才知道日志可以这么写,有兴趣可以去看一下,或者搜索最新的,毕竟也是一年前的文章了。

个人搭建的是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" /&
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值