我有两个使用Logback的Spring Boot(1.4.1-RELEASE)控制台应用程序。两个配置文件几乎完全相同,位于我的/src/main/resources文件夹中,并命名为logback-spring.xml。
这两个项目在它们的pom.xml中都包括Maven依赖项spring-boot-starter-logging,并获取Logback版本1.1.7。
在这两个pom中定义的Spring Boot配置:
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>1.4.1.RELEASE</version>
<relativePath />
</parent>
<groupId>d.m.v.app-a</groupId>
<artifactId>my-app-a</artifactId>
<version>1.0.16-SNAPSHOT</version>
<packaging>jar</packaging>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-security</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-logging</artifactId>
</dependency>
</dependencies>
然而,当运行应用程序时,其中一个似乎完全忽略了logback配置,而另一个则像预期的那样使用了它。
如果我将未正常工作的应用程序的文件名更改为logback.xml,它会突然正常工作(即使使用了我在其中使用的spring配置文件)。
在涉及的任何配置中都没有明显的差异(即pom.xml、application.properties等)。
有人知道为什么会出现这种情况吗?我觉得这种行为相当令人困惑。