0

0

在多模块Gradle项目中构建和消费内部插件

花韻仙語

花韻仙語

发布时间:2025-11-30 21:25:21

|

459人浏览过

|

来源于php中文网

原创

在多模块Gradle项目中构建和消费内部插件

本文详细阐述了在gradle多模块项目中构建和消费内部插件的策略。当插件作为项目内部模块存在时,gradle可能无法在构建其他模块之前发现并构建该插件。解决方案是利用gradle的复合构建(composite builds)特性,通过在根目录的`settings.gradle.kts`文件中使用`includebuild()`指令,强制gradle首先构建插件模块,并确保插件模块拥有独立的`settings.gradle.kts`文件。结合适当的插件版本解析策略,可以实现在同一仓库内无缝集成和使用内部插件。

理解多模块项目中的Gradle插件发现挑战

在复杂的软件项目中,将自定义的Gradle插件作为多模块项目的一部分进行开发和管理是一种常见需求。例如,一个库可能需要特定的构建配置,而这些配置可以通过一个内部开发的Gradle插件来自动化。然而,当尝试在同一多模块项目中的其他模块(例如my-implementation)中应用这个内部插件(my-gradle-plugin)时,开发者常常会遇到“插件未找到”的错误:

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

这个问题的核心在于Gradle在解析插件依赖时,默认情况下并不知道项目内部的插件模块需要首先被构建并发布(即使是本地发布)才能被其他模块使用。Gradle的插件解析机制通常会首先查找核心插件、插件门户(Gradle Plugin Portal)或配置的Maven/Ivy仓库。如果插件尚未被构建并存在于这些可解析的源中,就会导致上述错误。

解决方案核心:复合构建(Composite Builds)与includeBuild()

解决此问题的关键在于利用Gradle的复合构建(Composite Builds)特性。复合构建允许将独立的Gradle构建组合在一起,形成一个更大的、协同工作的构建。通过这种方式,我们可以将内部插件模块视为一个独立的构建,并将其“包含”到主构建中,从而强制Gradle在主构建开始解析依赖之前,先构建并使其插件可用。

要实现这一点,需要两个关键步骤:

  1. 为插件模块创建独立的settings.gradle.kts文件: 为了让Gradle将插件模块视为一个独立的构建,该模块内部必须包含自己的settings.gradle.kts文件(即使是空的)。这个文件标志着该目录是一个独立的Gradle构建根目录,从而将其与主项目的构建分离。

  2. 在根项目的settings.gradle.kts中使用includeBuild(): 在主项目的settings.gradle.kts文件中,使用pluginManagement { includeBuild("path/to/plugin-module") }指令。这会告诉Gradle:在解析插件依赖时,请首先考虑这个被包含的构建。Gradle会确保这个被包含的构建(即我们的插件模块)首先被构建,并且其提供的插件能够被主构建的其他模块发现和使用。

实施步骤:配置settings.gradle.kts

假设项目结构如下:

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

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

下载
+ root
  + my-api/
  + my-implementation/
  + my-gradle-plugin/
    + build.gradle.kts
    + settings.gradle.kts  // <-- 新增或确保存在
  + build.gradle.kts
  + gradle.properties
  + settings.gradle.kts
  1. 插件模块的build.gradle.kts配置: my-gradle-plugin/build.gradle.kts文件应包含标准的Gradle插件配置,例如:

    // my-gradle-plugin/build.gradle.kts
    plugins {
      `java-gradle-plugin`
      `maven-publish` // 如果需要发布到本地或远程仓库
    }
    
    gradlePlugin {
        plugins {
            create("myPluginId") {
                id = "org.my.gradle.plugin"
                group = "org.my.gradle.plugin"
                implementationClass = "org.my.gradle.plugin.MyGradlePlugin"
                version = project.version // 使用项目版本
            }
        }
    }
    
    group = "org.my.gradle.plugin"
    version = project.version
  2. 根项目的settings.gradle.kts配置: 这是最关键的配置。在根项目的settings.gradle.kts中,除了包含常规模块外,还需要在pluginManagement块中添加includeBuild("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") } // 你的私有Maven仓库
            gradlePluginPortal()
            mavenCentral()
        }
        resolutionStrategy {
            // 解析策略:确保内部插件使用项目定义的版本
            val version: String by settings
            eachPlugin {
                if (requested.id.id == "org.my.gradle.plugin") {
                    useVersion(version)
                }
            }
        }
    }

    请注意,gradle.properties文件中应定义项目版本,例如:version=0.0.3-SNAPSHOT。resolutionStrategy中的val version: String by settings会从gradle.properties中读取这个版本。

  3. 插件模块内部的settings.gradle.kts: 在my-gradle-plugin/目录下创建一个(或确保存在)settings.gradle.kts文件。这个文件可以为空,它的存在本身就是关键。

    // my-gradle-plugin/settings.gradle.kts
    // 这个文件可以为空,但必须存在,以将其标记为独立的构建

应用插件

完成上述配置后,在任何需要使用该插件的模块(例如my-implementation)的build.gradle.kts文件中,就可以像使用外部插件一样应用它了:

// my-implementation/build.gradle.kts
plugins {
   id("org.my.gradle.plugin") version "internal" // "internal" 或你在resolutionStrategy中指定的版本
}

// ... 其他构建配置

这里的version "internal"是一个占位符,实际版本将由根settings.gradle.kts中的resolutionStrategy根据gradle.properties中的版本进行解析。

注意事项

  • Gradle版本兼容性:上述includeBuild与pluginManagement结合使用的方法在Gradle 7.5及更高版本中得到了良好的支持。对于旧版本,可能需要查阅相应版本的文档。
  • 版本管理:通过resolutionStrategy集中管理内部插件的版本,可以确保整个多模块项目中的插件版本一致性,避免版本冲突。
  • 构建顺序:includeBuild()的引入使得Gradle能够智能地识别并优先构建被包含的插件项目,从而使其输出(插件Jar)在主构建的其他模块解析依赖时可用。
  • 理解复合构建:复合构建不仅仅用于插件,它还可以用于将多个独立的库项目组合到一个主构建中,实现跨项目依赖的本地开发和测试,而无需发布到本地Maven仓库。

总结

在多模块Gradle项目中构建和消费内部插件是一个常见的需求,通过巧妙地利用Gradle的复合构建特性,特别是includeBuild()指令和插件模块内部的settings.gradle.kts文件,可以有效地解决插件发现问题。这种方法不仅简化了开发工作流,还提高了项目内插件的集成效率和可维护性。遵循上述步骤,开发者可以在同一仓库内无缝地开发、构建和使用自定义的Gradle插件。

相关专题

更多
Java Maven专题
Java Maven专题

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

0

2025.09.15

string转int
string转int

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

318

2023.08.02

string转int
string转int

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

318

2023.08.02

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

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

31

2025.12.13

Java JVM 原理与性能调优实战
Java JVM 原理与性能调优实战

本专题系统讲解 Java 虚拟机(JVM)的核心工作原理与性能调优方法,包括 JVM 内存结构、对象创建与回收流程、垃圾回收器(Serial、CMS、G1、ZGC)对比分析、常见内存泄漏与性能瓶颈排查,以及 JVM 参数调优与监控工具(jstat、jmap、jvisualvm)的实战使用。通过真实案例,帮助学习者掌握 Java 应用在生产环境中的性能分析与优化能力。

13

2026.01.20

PS使用蒙版相关教程
PS使用蒙版相关教程

本专题整合了ps使用蒙版相关教程,阅读专题下面的文章了解更多详细内容。

60

2026.01.19

java用途介绍
java用途介绍

本专题整合了java用途功能相关介绍,阅读专题下面的文章了解更多详细内容。

87

2026.01.19

java输出数组相关教程
java输出数组相关教程

本专题整合了java输出数组相关教程,阅读专题下面的文章了解更多详细内容。

39

2026.01.19

java接口相关教程
java接口相关教程

本专题整合了java接口相关内容,阅读专题下面的文章了解更多详细内容。

10

2026.01.19

热门下载

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

精品课程

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

共23课时 | 2.7万人学习

C# 教程
C# 教程

共94课时 | 7.1万人学习

Java 教程
Java 教程

共578课时 | 48.5万人学习

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

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