在Springboot启动程序

时间:2016-11-02 21:58:12

标签: java spring spring-boot log4j2

我们正在尝试构建一个Springboot启动程序,它将以编程方式创建log4j2配置,因此开发人员不必费心创建log4j2.xml文件。问题是log4j2编程API在不同版本之间变化。我们已经使用log4j2版本2.5测试了我们的代码,它在独立环境中正常运行

现在我们正在尝试将我们的API包含在Springboot启动器中,这样所有springboot应用程序都可以包含此启动器,而不必担心log4j配置。

我们面临的问题是Springboot捆绑了自己的log4j版本,我们无法控制用户将使用哪个版本的Springboot。

有没有办法我们可以强制springboot启动器加载log4j2的2.5版本,否则我们的测试Springboot应用程序抱怨log4j中找不到某些方法

1 个答案:

答案 0 :(得分:1)

您可以通过在maven pom文件或gradle文件中声明它们来覆盖依赖项版本。

在maven中,要包含log4j2依赖项,您将排除默认的logback logger,然后添加以下依赖项

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

如果您检查此启动器pom的内容,则可以在其中看到以下依赖项

<dependency>
        <groupId>org.apache.logging.log4j</groupId>
        <artifactId>log4j-slf4j-impl</artifactId>
    </dependency>
    <dependency>
        <groupId>org.apache.logging.log4j</groupId>
        <artifactId>log4j-api</artifactId>
    </dependency>
    <dependency>
        <groupId>org.apache.logging.log4j</groupId>
        <artifactId>log4j-core</artifactId>
    </dependency>
    <dependency>
        <groupId>org.slf4j</groupId>
        <artifactId>jcl-over-slf4j</artifactId>
    </dependency>
    <dependency>
        <groupId>org.slf4j</groupId>
        <artifactId>jul-to-slf4j</artifactId>
    </dependency>

为了覆盖管理版本的任何这些依赖项,您可以在pom文件中重新声明这些依赖项,并为其提供“version”标记。只需包含此

 <dependency>
<groupId>org.apache.logging.log4j</groupId>
<artifactId>log4j-api</artifactId>
<version>2.5</version>
</dependency>
<dependency>
<groupId>org.apache.logging.log4j</groupId>
<artifactId>log4j-core</artifactId>
<version>2.5</version>
</dependency>
你的pom文件中的

。像Maven和Gradle这样的依赖管理工具支持这种覆盖。