使用log4j2进行Spring Boot日志记录?

22

我正在使用 spring-boot-starter,并想要配置 log4j2.xml 以异步记录不同内容到不同的日志文件。

我已经创建了 log4j2 文件,但是 Spring 仍然使用 spring-boot 的默认日志记录。如何切换日志记录?

3个回答

52

我有更好的方式:

  1. 排除 logback 日志记录器:

    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter</artifactId>
        <exclusions>
            <exclusion>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-logging</artifactId>
            </exclusion>
        </exclusions>
    </dependency>
    
  2. 添加log4j2引导器:

  3. <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-log4j2</artifactId>
    </dependency>
    

来源:http://docs.spring.io/spring-boot/docs/1.5.1.RELEASE/reference/htmlsingle/#howto-configure-log4j-for-logging

祝愉快!


我认为你的意思是:“排除logback框架”,而不是“排除slf4j日志记录器”,对吗? - Daniel Marcotte
此外,请确保在使用log4j2时使用<artifactId>spring-boot-starter-log4j2</artifactId>,因为<artifactId>spring-boot-starter-log4j</artifactId>是有效的但不适用于log4j2。 - kervin
对我来说,我需要添加这两个: <exclusion> <artifactId>logback-classic</artifactId> <groupId>ch.qos.logback</groupId> </exclusion> <exclusion> <artifactId>log4j-over-slf4j</artifactId> <groupId>org.slf4j</groupId> </exclusion>
</exclusions>
- vsingh
1
对于我来说,使用Gradle,我只需执行以下操作:configurations.all*.exclude group: 'org.springframework.boot', module: 'spring-boot-starter-logging'然后在我的dependencies{}部分中添加 runtime 'org.springframework.boot:spring-boot-starter-log4j2' - Eric
1
对我来说它不起作用:所有日志都打印到控制台。 - Denys

11

试试这个:

  1. 排除 spring-boot-starter-logging,例如:

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter</artifactId>
    <exclusions>
        <exclusion>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-logging</artifactId>
        </exclusion>
    </exclusions>
</dependency>
  • 为您的日志记录接口添加依赖项,例如 slf4j

  • <dependency>
        <groupId>org.apache.logging.log4j</groupId>
        <artifactId>log4j-slf4j-impl</artifactId>
        <version>2.0.2</version>
    </dependency>
    
  • 添加指向所选日志接口的其他日志记录实现,例如:

  • <dependency>
        <groupId>org.slf4j</groupId>
        <artifactId>jcl-over-slf4j</artifactId>
    </dependency>
    <dependency>
        <groupId>org.slf4j</groupId>
        <artifactId>jul-to-slf4j</artifactId>
    </dependency>
    <dependency>
        <groupId>org.slf4j</groupId>
        <artifactId>log4j-over-slf4j</artifactId>
    </dependency>
    
  • 添加您的目标日志记录实现,例如:

    <dependency>
        <groupId>org.apache.logging.log4j</groupId>
        <artifactId>log4j-api</artifactId>
        <version>2.0.2</version>
    </dependency>
    <dependency>
        <groupId>org.apache.logging.log4j</groupId>
        <artifactId>log4j-core</artifactId>
        <version>2.0.2</version>
    </dependency>
    
  • 而且它应该能够正常工作。


    7
    现在,自从Spring Boot 1.2.0.RELEASE版本开始,也有了spring-boot-starter-log4j2。这只是作为参考信息。 - membersound
    这对我也不起作用:所有日志都会打印到控制台。 - Denys

    2

    这是对我有效的解决方案。需要添加两个额外的排除项,否则应用程序无法捕获log4j并会出现冲突。

    实际绑定类型为[ch.qos.logback.classic.util.ContextSelectorStaticBinder]

    <dependency>
        <groupId>org.mybatis.spring.boot</groupId>
        <artifactId>mybatis-spring-boot-starter</artifactId>
        <version>1.0.0</version>
        <exclusions>
            <exclusion>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-logging</artifactId>
            </exclusion>
            <exclusion>
                <artifactId>logback-classic</artifactId>
                <groupId>ch.qos.logback</groupId>
            </exclusion>
            <exclusion>
                <artifactId>log4j-over-slf4j</artifactId>
                <groupId>org.slf4j</groupId>
            </exclusion>            
        </exclusions>           
    </dependency>
    
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-log4j2</artifactId>
    </dependency>
    

    网页内容由stack overflow 提供, 点击上面的
    可以查看英文原文,
    原文链接