登录
首页 >  文章 >  java教程

springboot整合log4j报错怎么解决

来源:亿速云

时间:2024-04-15 14:51:34 178浏览 收藏

欢迎各位小伙伴来到golang学习网,相聚于此都是缘哈哈哈!今天我给大家带来《springboot整合log4j报错怎么解决》,这篇文章主要讲到等等知识,如果你对文章相关的知识非常感兴趣或者正在自学,都可以关注我,我会持续更新相关文章!当然,有什么建议也欢迎在评论留言提出!一起学习!

    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。

    日志模式使用注意事项:

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

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

    日志滚动和清除策略

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

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

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

    以上就是本文的全部内容了,是否有顺利帮助你解决问题?若是能给你带来学习上的帮助,请大家多多支持golang学习网!更多关于文章的相关知识,也可关注golang学习网公众号。

    声明:本文转载于:亿速云 如有侵犯,请联系study_golang@163.com删除
    相关阅读
    更多>
    最新阅读
    更多>
    课程推荐
    更多>