spring - spring 依赖管理 gradle 插件不下载依赖
问题描述
我在 IntelliJ 上使用 spring 依赖管理 gradle 插件。我有一个带有以下内容的根模块
apply plugin: "io.spring.dependency-management"
dependencyManagement {
dependencies {
dependencySet(group: "org.apache.hadoop", version: "2.6.0-cdh5.14.4") {
entry "hadoop-common"
entry "hadoop-hdfs"
}
}
}
如果我添加
dependency 'org.apache.hadoop:hadoop-tools:2.6.0-mr1-cdh5.14.4'
或者
dependencySet(group: "org.apache.hadoop", version: "2.6.0-mr1-cdh5.14.4") {
entry ("hadoop-tools") {
exclude group: 'ch.qos.logback', module: 'logback-classic'
exclude group: 'org.slf4j', module: 'slf4j-log4j12'
}
}
在根模块中,它不会下载hadoop-tools
jar。仅当我在子模块中添加以下内容时,它才会下载此依赖项。
plugins {
id "com.github.johnrengelman.shadow" version "2.0.4"
}
dependencies {
compile ("org.apache.hadoop:hadoop-tools:2.6.0-mr1-cdh5.14.4") {
exclude group: 'ch.qos.logback', module: 'logback-classic'
exclude group: 'org.slf4j', module: 'slf4j-log4j12'
}
}
为什么是这种行为?
解决方案
为了理解这种行为,您需要了解 Spring DependencyManagement 插件的工作原理(请参阅 官方文档中的此部分):
- dependencyManagement { }块用于配置将应用于依赖项的约束(要使用的版本、传递依赖项的排除项等),但此块不会将这些依赖项应用于您的项目,
- 必须使用dependencies{ }块配置项目的依赖项
在您的示例中:
首先,您在根项目中配置了对“hadoop-common”和“hadoop-hdfs”模块的约束的dependencyManagement块,然后在“hadoop-tools”上添加了约束(在dependencyManagement块中使用“dependency”或“dependencySet” ) : 在这个阶段,你还没有显式的添加任何依赖到你的项目中,只是配置了依赖约束
==> 这解释了为什么“hadoop-tools”依赖项没有添加/下载到您的项目中。
然后您使用dependencies块添加了对“hadoop-tools”的“编译”依赖项,这是声明依赖项的正确方法,这使得“hadoop-tools”库在您的项目中可用。
如果我很好地理解您的要求,根据您在问题中提供的源代码:您可以按如下方式配置您的项目:
根项目的脚本
buildscript {
repositories {
jcenter()
}
dependencies {
classpath "org.springframework.boot:spring-boot-gradle-plugin:2.0.4.RELEASE"
}
}
// configure plugins to be applied and dependencies contraints for all subprojects
subprojects {
apply plugin: 'java'
apply plugin: io.spring.gradle.dependencymanagement.DependencyManagementPlugin
dependencyManagement {
dependencies {
// set version for hadoop-common & hadoop-hdfs to "2.6.0-cdh5.14.4"
dependencySet(group: "org.apache.hadoop", version: "2.6.0-cdh5.14.4") {
entry "hadoop-common"
entry "hadoop-hdfs"
}
// set version "2.6.0-mr1-cdh5.14.4" for hadoop-tool,
// and exclude slf4j-log4j12 module from transitive dependencies
dependency (group: "org.apache.hadoop" , name: "hadoop-tools", version : "2.6.0-mr1-cdh5.14.4") {
exclude 'org.slf4j:slf4j-log4j12'
}
}
}
repositories {
jcenter()
maven {
url = 'https://repository.cloudera.com/content/repositories/releases/'
}
}
}
子项目脚本
dependencies{
// hadoop-tools module version is defined (constrained)
// by dependencyManagement in root project build script
compile 'org.apache.hadoop:hadoop-tools'
}
推荐阅读
- python - 为什么将 GEKKO 与 linux APM 求解服务器一起使用时,周期时间会持续增加?
- scala - 在scala中创建具有键值对的数据框
- python - 跨多个列的 Pandas 代表性抽样
- html - 我们如何在带有链接的图像上添加声音?
- spring-batch - Spring Batch:设置自定义 BatchConfigurer 后,写入器的 JPA 存储库不起作用
- r - 在 MatchIt 包中使用 Mahalonobis 距离和卡尺
- c - 有选择地忽略换行符?
- async-await - Blazor、Httpclient、同步和异步 WebApi 调用
- android - 在颤振中找不到android的路径错误
- sql - 如何使用 Bigquery 和 Firebase 数据查找用户在一个会话中执行“NowPlayingActivity”所需的时间?