0

0

在Gradle多模块项目中构建与消费自定义插件的指南

碧海醫心

碧海醫心

发布时间:2025-11-30 20:13:02

|

685人浏览过

|

来源于php中文网

原创

在Gradle多模块项目中构建与消费自定义插件的指南

本文探讨了在gradle多模块项目中构建和消费自定义插件时遇到的“插件未找到”问题及其解决方案。核心在于利用gradle的复合构建(composite builds)功能,通过在根项目的`settings.gradle.kts`中使用`includebuild()`指令,并为插件模块提供独立的`settings.gradle.kts`文件,确保插件在被其他模块消费前得到正确构建和解析。这使得插件能够无缝集成到同一项目结构中,简化了开发工作流。

在大型多模块项目中,为了统一和简化特定模块的构建配置,开发自定义Gradle插件是一种常见且高效的实践。例如,一个库可能需要针对其依赖项目配置特定的测试套件,此时一个自定义插件就能自动化这些配置。然而,当尝试在同一个多模块项目内部构建并消费这个插件时,开发者可能会遇到“插件未找到”的问题。

挑战:在多模块项目中消费内部插件

通常,一个Gradle多模块项目的结构可能如下所示:

+ root
  + my-api/          // 接口模块
  + my-implementation/ // 实现模块,依赖my-api并尝试消费自定义插件
  + my-gradle-plugin/  // 自定义Gradle插件模块
    + build.gradle.kts
  + build.gradle.kts   // 根项目构建脚本
  + settings.gradle.kts // 根项目设置脚本
  + gradle.properties

其中,my-gradle-plugin模块负责定义和实现自定义插件。其build.gradle.kts可能包含如下配置:

// my-gradle-plugin/build.gradle.kts
plugins {
    `java-gradle-plugin`
    `maven-publish`
}

gradlePlugin {
    plugins {
        create("org.my.gradle.plugin") {
            id = "org.my.gradle.plugin"
            group = "org.my.gradle.plugin"
            implementationClass = "org.my.gradle.plugin.MyGradlePlugin"
            version = project.version
        }
    }
}

当my-implementation模块尝试通过plugins { id("org.my.gradle.plugin") version "internal" }来应用这个插件时,Gradle可能会报告以下错误:

* What went wrong:
Plugin [id: 'org.my.gradle.plugin', version: '0.0.3-SNAPSHOT'] was not found in any of the following sources:

- Gradle Core Plugins (plugin is not in 'org.gradle' namespace)
- Plugin Repositories (could not resolve plugin artifact 'org.my.gradle.plugin:org.my.gradle.plugin.gradle.plugin:0.0.3-SNAPSHOT')
  Searched in the following repositories:
    MavenLocal(...)
    maven(...)
    Gradle Central Plugin Repository
    MavenRepo

这个错误表明Gradle在解析my-implementation模块时,无法在配置的插件仓库中找到org.my.gradle.plugin。问题在于,Gradle默认并不知道my-gradle-plugin模块需要先被构建成一个可用的插件,才能在同一个构建过程中被其他模块消费。它会将插件视为外部依赖,尝试从远程或本地Maven仓库中查找。

极品HTML5网络建站公司模板源码(包含源文件)3.0
极品HTML5网络建站公司模板源码(包含源文件)3.0

1、架构轻盈,完全免费与开源采用轻量MVC架构开发,兼顾效率与拓展性。全局高效缓存,打造飞速体验。 2、让简洁与强大并存强大字段自定义功能,完善的后台开关模块,不会编程也能搭建各类网站系统。 3、顶级搜索引擎优化功能纯静态、伪静态,全部支持自由设置规则,内容、栏目自由设置URL格式。 4、会员、留言、投稿、支付购物神马一个不能少不断升级完善的模块与插件,灵活的组装与自定义设置,满足你的多样需求。

下载

解决方案:利用Gradle复合构建(Composite Builds)

解决这个问题的关键在于利用Gradle的复合构建(Composite Builds)功能。复合构建允许将多个独立的Gradle构建(包括插件项目)组合成一个单一的构建。这样,主构建就可以在本地解析和使用“包含”的构建所提供的插件或项目。

具体步骤如下:

  1. 为插件模块创建独立的settings.gradle.kts: 在my-gradle-plugin模块的根目录下创建一个空的settings.gradle.kts文件。这个文件将把my-gradle-plugin标记为一个独立的Gradle构建,使其能够被主项目作为复合构建的一部分来“包含”。即使是空文件,它的存在也是必要的。

    + root
      + my-gradle-plugin/
        + build.gradle.kts
        + settings.gradle.kts // 新增文件
  2. 在根项目的settings.gradle.kts中声明includeBuild(): 在主项目的settings.gradle.kts中,使用includeBuild()指令将my-gradle-plugin模块作为复合构建包含进来。这会告诉Gradle,在构建主项目之前,需要先构建my-gradle-plugin。

    // ./root/settings.gradle.kts
    
    rootProject.name = "root-project"
    
    // 包含其他子模块
    include("my-api", "my-implementation")
    
    // 关键:将插件模块作为复合构建包含进来
    pluginManagement {
        includeBuild("my-gradle-plugin") // 指向插件模块的路径
        repositories {
            mavenLocal()
            maven { url = uri("https://xyz") } // 你的私有仓库
            gradlePluginPortal()
            mavenCentral()
        }
        resolutionStrategy {
            val version: String by settings
            eachPlugin {
                // 确保自定义插件使用根项目定义的版本
                if (requested.id.id == "org.my.gradle.plugin") {
                    useVersion(version)
                }
            }
        }
    }
    • includeBuild("my-gradle-plugin"): 这行代码指示Gradle将my-gradle-plugin目录下的项目视为一个独立的构建,并将其纳入当前构建的范围。Gradle会确保在需要该插件时,它已经被构建并可用。
    • pluginManagement块中的resolutionStrategy: 这是一个最佳实践,确保你的自定义插件能够正确解析到根项目gradle.properties中定义的版本(例如version=0.0.3-SNAPSHOT),而不是尝试从远程仓库查找特定版本。version: String by settings用于从settings.gradle.kts中获取gradle.properties定义的属性。
  3. 消费插件: 完成上述配置后,my-implementation模块就可以像消费任何其他插件一样,直接应用自定义插件了。

    // my-implementation/build.gradle.kts
    plugins {
       id("org.my.gradle.plugin") version "internal" // "internal" 或具体的版本号,取决于resolutionStrategy
    }

    这里使用"internal"作为版本号,是因为pluginManagement中的resolutionStrategy会强制使用根项目定义的版本。如果你的resolutionStrategy配置不同,你可能需要指定实际的版本号。

注意事项

  • Gradle版本兼容性: 上述方法在Gradle 7.5及更高版本中验证有效。对于更早的Gradle版本,行为可能有所不同,建议查阅对应版本的Gradle文档。
  • 插件模块的独立性: 在插件模块内部添加settings.gradle.kts,即使是空文件,也至关重要。它将该模块提升为一个独立的Gradle构建,使得includeBuild()能够识别并管理它。
  • 版本管理: 推荐使用resolutionStrategy来统一管理自定义插件的版本,使其与主项目的版本保持一致,避免因版本不匹配导致的问题。

通过采用复合构建和includeBuild()机制,开发者可以在一个统一的多模块项目中无缝地构建和消费自定义Gradle插件,极大地简化了开发和维护工作流,提升了项目的模块化和可配置性。

相关专题

更多
Java Maven专题
Java Maven专题

本专题聚焦 Java 主流构建工具 Maven 的学习与应用,系统讲解项目结构、依赖管理、插件使用、生命周期与多模块项目配置。通过企业管理系统、Web 应用与微服务项目实战,帮助学员全面掌握 Maven 在 Java 项目构建与团队协作中的核心技能。

0

2025.09.15

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

338

2023.08.02

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

338

2023.08.02

PHP 命令行脚本与自动化任务开发
PHP 命令行脚本与自动化任务开发

本专题系统讲解 PHP 在命令行环境(CLI)下的开发与应用,内容涵盖 PHP CLI 基础、参数解析、文件与目录操作、日志输出、异常处理,以及与 Linux 定时任务(Cron)的结合使用。通过实战示例,帮助开发者掌握使用 PHP 构建 自动化脚本、批处理工具与后台任务程序 的能力。

32

2025.12.13

Golang 性能分析与pprof调优实战
Golang 性能分析与pprof调优实战

本专题系统讲解 Golang 应用的性能分析与调优方法,重点覆盖 pprof 的使用方式,包括 CPU、内存、阻塞与 goroutine 分析,火焰图解读,常见性能瓶颈定位思路,以及在真实项目中进行针对性优化的实践技巧。通过案例讲解,帮助开发者掌握 用数据驱动的方式持续提升 Go 程序性能与稳定性。

9

2026.01.22

html编辑相关教程合集
html编辑相关教程合集

本专题整合了html编辑相关教程合集,阅读专题下面的文章了解更多详细内容。

56

2026.01.21

三角洲入口地址合集
三角洲入口地址合集

本专题整合了三角洲入口地址合集,阅读专题下面的文章了解更多详细内容。

30

2026.01.21

AO3中文版入口地址大全
AO3中文版入口地址大全

本专题整合了AO3中文版入口地址大全,阅读专题下面的的文章了解更多详细内容。

393

2026.01.21

妖精漫画入口地址合集
妖精漫画入口地址合集

本专题整合了妖精漫画入口地址合集,阅读专题下面的文章了解更多详细内容。

116

2026.01.21

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 2.8万人学习

C# 教程
C# 教程

共94课时 | 7.3万人学习

Java 教程
Java 教程

共578课时 | 49.4万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号