为了账号安全,请及时绑定邮箱和手机立即绑定

SpringBoot学习--09配置log4j2日志详解(下)--升级改造(异步,适配)

标签:
SpringBoot

上篇我们完成了log4j2的日志配置,但是log4j2最好的地方就是异步日志模式,所以在这里我们就要进行升级改造.

  • 异步改造(混合异步输出:控制台同步输出,保存日志异步输出)

  • 在pom.xml中导入log4j2日志的异步依赖
    <!-- log4j2异步依赖包 -->
    <dependency>
      <groupId>com.lmax</groupId>
      <artifactId>disruptor</artifactId>
      <version>3.4.2</version>
    </dependency>
  • 修改xml中的配置:
# 原有配置<Loggers>
    <!--过滤掉spring和mybatis的一些无用的DEBUG信息-->
    <logger name="org.springframework" level="INFO" />
    <logger name="org.mybatis" level="INFO" />
    <!-- 配置日志的根节点 -->
    <!-- 定义logger,只有定义了logger并引入了appender,appender才会生效 -->
    <root level="${OUT_LOG_LEVEL}">
      <appender-ref ref="console_out_appender" />
      <appender-ref ref="console_err_appender" />
      <appender-ref ref="trace_appender" />
      <appender-ref ref="debug_appender" />
      <appender-ref ref="info_appender" />
      <appender-ref ref="warn_appender" />
      <appender-ref ref="error_appender" />
    </root>
  </Loggers>

修改后的配置:

  <Loggers>
    <!--过滤掉spring和mybatis的一些无用的DEBUG信息-->
    <logger name="org.springframework" level="INFO" />
    <logger name="org.mybatis" level="INFO" />
    <!-- 配置日志的根节点 -->
    <!-- 定义logger,只有定义了logger并引入了appender,appender才会生效 -->
   <!-- 打印日志同步输出 -->
    <root level="${OUT_LOG_LEVEL}" includeLocation="true">
      <appender-ref ref="console_out_appender" />
      <appender-ref ref="console_err_appender" />
    </root>
    <!-- 保存日志异步输出 -->
    <AsyncLogger level="${OUT_LOG_LEVEL}" includeLocation="true">
      <appender-ref ref="trace_appender" />
      <appender-ref ref="debug_appender" />
      <appender-ref ref="info_appender" />
      <appender-ref ref="warn_appender" />
      <appender-ref ref="error_appender" />
    </AsyncLogger>
  </Loggers>
  • 很多时候项目中的日志系统没有导入log4j2的依赖包,使用接口会出现错误.现在将日志系统重构成基于Slf4j和log4j2的日志系统,使用slf4j可以很好的保证我们的日志系统具有良好的兼容性,兼容当前常见几种日志系统,不会出现异常.


  1. 在pom.xml导入slf4j和log4j2的桥接包,

    <!-- https://mvnrepository.com/artifact/org.apache.logging.log4j/log4j-slf4j-impl -->
    <dependency>
        <groupId>org.apache.logging.log4j</groupId>
        <artifactId>log4j-slf4j-impl</artifactId>
    </dependency>
     <!-- https://mvnrepository.com/artifact/org.slf4j/slf4j-api -->
    <dependency>
        <groupId>org.slf4j</groupId>
        <artifactId>slf4j-api</artifactId>
    </dependency>

  1. 使用时将log导入包替换,如下所示:

#替换前import org.apache.logging.log4j.LogManager;import org.apache.logging.log4j.Logger;private static final Logger log = LogManager.getLogger(SysDepartmentController.class);
#替换后import org.slf4j.Logger;import org.slf4j.LoggerFactory;private static final Logger log = LoggerFactory.getLogger(SysDepartmentController.class);

其输出效果是一样的,但是项目作为接口的时候不会因为没有导入log4j2的依赖包而出现异常.



作者:渊默十三
链接:https://www.jianshu.com/p/7133f436772b


点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
JAVA开发工程师
手记
粉丝
205
获赞与收藏
1007

关注作者,订阅最新文章

阅读免费教程

  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消