我有自己的slf4j实现,所以我想从许多依赖项中删除logback,例如。
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
<version>...</version>
<exclusions>
<exclusion>
<artifactId>logback-classic</artifactId>
<groupId>ch.qos.logback</groupId>
</exclusion>
</exclusions>
</dependency>
...
但我通过将其添加为测试范围找到了一种快捷方式:
<dependency>
<artifactId>logback-classic</artifactId>
<groupId>ch.qos.logback</groupId>
<version>...</version>
<scope>test</scope>
</dependency>
这是maven的好习惯吗?
答案 0 :(得分:4)
我可以看到测试范围是如何做到的,但我个人反对这样的黑客攻击。如果你的团队松散的纪律并开始将hacks加入你的应用程序只是为了节省几行代码,你的应用程序很快就会无法维护。
您也不应该指定spring托管依赖项的版本。您应该只在pom的parent
部分定义Spring启动版本。您可以在spring-boot-dependencies
文件中找到spring托管依赖项的矩阵。
我建议直接排除spring-boot-starter-logging
而不是logback。因此,如果您正在使用log4j2(希望您不再计划使用log4j
),请执行以下操作:
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>1.3.6.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
<exclusions>
<exclusion>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-logging</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-log4j2</artifactId>
</dependency>