0

0

springboot整合log4j报错怎么解决

王林

王林

发布时间:2023-05-11 10:07:05

|

2527人浏览过

|

来源于亿速云

转载

    1、依赖添加

     1.1、添加依赖

    需要引入 log4j 的依赖支持,推荐自己确定使用的版本。

    
            org.apache.logging.log4j
            log4j-to-slf4j
            2.11.2
    

     1.2、剔除依赖

    springboot 默认自己内部添加了对日志的支持,需要将其全部剔除掉,不然会影响 log4j 的依赖使用。

    
            org.springframework.boot
            spring-boot-starter-logging
            
                
                   *
                    *
                
            
    

    2、配置日志

     2.1、日志打印记录

     根据自己的需求进行相关的配置,这里需要注意的是使用 xml 文件进行配置,使用 properties 有坑没爬起来,文件名自定义,没有啥要求,都会在配置文件中进行指定的。

    
    
        beordie
        
        
        
        
        
    
        
            
                info
            
            
                ${CONSOLE_LOG_PATTERN}
                UTF-8
            
        
    
        
            ${path}/debug.log
            
                %d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n
                UTF-8
            
            
                ${log}/debug/log-debug-%d{yyyy-MM-dd}.%i.log
                
                    100MB
                
                15
            
            
                debug
                ACCEPT
                DENY
            
        
    
        
            ${log}/info.log
            
                %d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n
                UTF-8
            
            
                ${log}/info/log-info-%d{yyyy-MM-dd}.%i.log
                
                    100MB
                
                15
            
            
                info
                ACCEPT
                DENY
            
        
    
        
            ${log}/warn.log
            
                %d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n
                UTF-8
            
            
                ${log}/warn/log-warn-%d{yyyy-MM-dd}.%i.log
                
                    100MB
                
                15
            
            
                warn
                ACCEPT
                DENY
            
        
    
        
            ${log}/error.log
            
                %d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n
                UTF-8
            
            
                ${log}/error/log-error-%d{yyyy-MM-dd}.%i.log
                
                    100MB
                
                15
            
            
                ERROR
                ACCEPT
                DENY
            
        
    
        
            
        
    
        
            
            
            
            
            
        
    

     2.2、指定配置文件

    还需要在 spring boot 的项目配置文件中进行配置的指定。

    logging:
      config: classpath:log4j.xml

    到这里完成对日志的整体配置,启动项目通过下面语句拿到日志对象即可进行日志的打印输出。

    private final Logger LOGGING = LoggerFactory.getLogger(ArticleController.class);

    补充:log4j调优和注意事项

    日志模式-同步/异步

    log4j2提供了AsyncAppender和AsyncLogger以及全局异步,开启方式如下:

    • 同步模式:默认配置即为同步模式,即没有使用任何AsyncAppender和AsyncLogger。

    • 全局异步:配置按照同步方式配,通过添加jvm启动参数即可开启全局异步,无需修改配置和应用。

    • 混合异步:使用异步Logger和同步Logger的混合配置,且不开启全局异步,即Logger配置中部分AsyncLogger,部分Logger。

      CodiumAI
      CodiumAI

      AI代码测试工具,在IDE中获得重要的测试建议

      下载

    日志模式使用注意事项:

    • 如果使用异步,建议使用AsyncLogger实现而不是AsyncAppender。

    • 如果使用同步,AsyncLogger、AsyncAppender和全局异步只能使用一种,不可以同时配置AsyncAppender和AsyncLogger,或者配置了异步的情况下启用了全局异步。

    日志滚动和清除策略

    log4j2提供了基于文件大小的滚动策略和基于时间的滚动策略,也可以二者并用,这里给出基于大小的滚动策略配置和基于大小/时间双滚动策略配置:

    • 基于大小的滚动策略:按照大小滚动,启用压缩,并最多保留N个文件

    • 基于大小/时间双滚动滚动策略:按照大小和时间滚动,启用压缩,单位时间内控制最多保留日志个数并控制总的日志留存时间。

    相关专题

    更多
    c++ 根号
    c++ 根号

    本专题整合了c++根号相关教程,阅读专题下面的文章了解更多详细内容。

    57

    2026.01.23

    c++空格相关教程合集
    c++空格相关教程合集

    本专题整合了c++空格相关教程,阅读专题下面的文章了解更多详细内容。

    57

    2026.01.23

    yy漫画官方登录入口地址合集
    yy漫画官方登录入口地址合集

    本专题整合了yy漫画入口相关合集,阅读专题下面的文章了解更多详细内容。

    237

    2026.01.23

    漫蛙最新入口地址汇总2026
    漫蛙最新入口地址汇总2026

    本专题整合了漫蛙最新入口地址大全,阅读专题下面的文章了解更多详细内容。

    393

    2026.01.23

    C++ 高级模板编程与元编程
    C++ 高级模板编程与元编程

    本专题深入讲解 C++ 中的高级模板编程与元编程技术,涵盖模板特化、SFINAE、模板递归、类型萃取、编译时常量与计算、C++17 的折叠表达式与变长模板参数等。通过多个实际示例,帮助开发者掌握 如何利用 C++ 模板机制编写高效、可扩展的通用代码,并提升代码的灵活性与性能。

    17

    2026.01.23

    php远程文件教程合集
    php远程文件教程合集

    本专题整合了php远程文件相关教程,阅读专题下面的文章了解更多详细内容。

    103

    2026.01.22

    PHP后端开发相关内容汇总
    PHP后端开发相关内容汇总

    本专题整合了PHP后端开发相关内容,阅读专题下面的文章了解更多详细内容。

    73

    2026.01.22

    php会话教程合集
    php会话教程合集

    本专题整合了php会话教程相关合集,阅读专题下面的文章了解更多详细内容。

    81

    2026.01.22

    宝塔PHP8.4相关教程汇总
    宝塔PHP8.4相关教程汇总

    本专题整合了宝塔PHP8.4相关教程,阅读专题下面的文章了解更多详细内容。

    70

    2026.01.22

    热门下载

    更多
    网站特效
    /
    网站源码
    /
    网站素材
    /
    前端模板

    精品课程

    更多
    相关推荐
    /
    热门推荐
    /
    最新课程
    Redis6入门到精通超详细教程
    Redis6入门到精通超详细教程

    共47课时 | 5.3万人学习

    关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
    php中文网:公益在线php培训,帮助PHP学习者快速成长!
    关注服务号 技术交流群
    PHP中文网订阅号
    每天精选资源文章推送

    Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号