DPE 大学上线了! 了解更多关于 Gradle 构建工具、Gradle 构建扫描、Develocity 和生态系统的信息 close - Gradle 构建系统

Gradle 构建工具特性

这个 Gradle 构建工具特性的分类列表将帮助您了解 Gradle 构建工具在您的用例中的一些功能。请查阅用户指南作为参考,并查看Gradle 构建工具教程以开始使用。

目录

运行 Gradle 构建

这些功能影响运行 Gradle 构建的开发者,并且可以被任何运行 Gradle 的人利用。

性能

增量构建

Gradle 在构建之间检查自上次构建调用以来,任务的输入、输出或实现是否已更改。如果未更改,则任务被认为是最新的,不需要执行。Gradle 还将任务的配置视为其输入的一部分。

构建缓存

如果任务已经在另一台计算机上执行过,Gradle 可以跳过本地执行,而是从构建缓存中加载任务的输出。典型的用例是让 CI 构建推送到共享构建缓存,并允许开发者从中拉取。本地构建缓存也可用,以重用在同一机器上较早生成的任务输出。

增量任务

当 Gradle 发现任务的输入或输出在构建运行之间发生更改时,该任务将再次执行。任务可以使用增量 API 来了解具体哪些文件已更改。有了这些信息,任务可能不需要重建所有内容。

增量注解处理

当存在受支持的注解处理器时,增量注解处理显著提高了增量编译的效率。

编译器守护进程

当您需要 fork 编译过程时,Gradle 会创建一个守护进程,该守护进程在多项目构建中重复使用。这为编译过程提供了显著的速度提升。

并行执行

Gradle 允许通过 Worker API 并行执行任务和任务内工作。并行性非常精细,从而实现更快的性能。

并行下载依赖

Gradle 将并行下载依赖元数据(通常是 `pom.xml`)和工件。这仅在需要工件时按需完成。

任务超时

每个任务都有一个超时属性,可用于限制其执行时间。当任务达到超时时,其任务执行线程将被中断,从而允许构建完成。

构建扫描

基于 Web 的构建可视化

通过丰富的 Web 界面而不是文本控制台和文本文件,了解您的构建中发生了什么。构建扫描提供更多信息,并且更有效。

协作调试

与同事分享构建扫描,以高效地解决问题并共同改进。分享完整的扫描或专注于特定构建方面的链接,例如日志输出行。

扩展和自定义

将您自己的数据作为标签、值和链接添加到构建扫描中。将构建扫描集成到您的工具链中。

精细的构建比较 [Develocity]

构建扫描比较快速突出显示构建之间的差异,例如依赖项及其版本,从而使根本原因分析更快。

跨所有构建跟踪和导出历史记录 [Develocity]

跟踪所有构建的关键构建指标,包括本地开发构建,而不仅仅是 CI 构建。了解趋势并将构建扫描数据导出到您选择的存储。

执行选项

持续构建

当 Gradle 任务以持续模式运行时,Gradle 会自动监视此任务输入的变化。每当输入发生变化时,任务都会自动执行。您可以在多项目构建中持续运行多个任务。

复合构建

复合构建允许您包含其他独立项目,以便您可以同时开发应用程序及其依赖的库。它们默认并行构建,并且可以嵌套。

任务排除

您可以排除任何任务不运行。当您排除一个任务时,此任务依赖的所有任务也会自动排除,如果它们没有其他依赖项。

空运行

运行构建以查看实际执行哪些任务,而无需执行任务操作。

在失败后继续执行

构建在遇到第一个失败时不会停止。这使得可以在单个构建执行中发现尽可能多的失败,并在最后提供非常好的聚合错误报告。

快速失败测试执行

尽管在 Gradle 中,测试失败后继续是默认设置,但您可以设置 `--fail-fast` 标志或为 Gradle 构建配置 `failFast=true`,以便在其中一个测试失败时立即失败并完成。

将依赖缓存与仓库同步

Gradle 有一个 `--refresh-dependencies` 选项,用于忽略已解析模块和工件的所有缓存条目。将针对所有配置的仓库执行新的解析,重新计算动态版本,刷新模块并下载工件。但是,Gradle 将检查先前下载的工件是否有效,然后再重新下载它们。这是通过比较仓库中发布的 SHA1 值与现有下载工件的 SHA1 值来完成的。

↑ 目录

编写 Gradle 构建

这些功能影响构建作者和那些负责开发者生产力的人员。

构建逻辑是可测试的代码

Groovy DSL

理想情况下,Groovy 构建脚本看起来很像配置,包括设置一些项目属性、配置依赖项、声明任务等。该配置基于 Groovy 语言结构。

Kotlin DSL

Gradle 的 Kotlin DSL 为传统的 Groovy DSL 提供了一种替代语法,在受支持的 IDE 中具有增强的编辑体验、卓越的内容辅助、重构、文档等。

Gradle Init 插件

Gradle Build Init 插件可以创建各种类型的新 Gradle 构建(Java 应用程序、Java 库、Groovy 库、Kotlin 应用程序等),或将现有构建(例如,Apache Maven 构建)转换为 Gradle 构建。

依赖管理

传递依赖

使用依赖管理系统的主要好处之一是管理传递依赖。Gradle 负责下载和管理传递依赖。

自定义依赖范围

不要受限于预定义的依赖范围集(compile、runtime 等)。Gradle 允许您定义任意依赖范围。例如,对于您可能在构建中建模的集成测试,为您在构建中需要的工具链提供配置等。

基于文件的依赖

并非所有依赖都可从外部仓库获得。当托管依赖不切实际或迁移旧构建时,声明对文件系统资源的依赖可能很有用。

自定义仓库布局

声明具有自定义布局的仓库。使用自定义布局,您可以有效地将几乎任何文件系统目录结构视为工件仓库。

第三方依赖缓存

来自远程仓库的依赖项被下载并在本地缓存。后续构建使用缓存的工件以避免不必要的网络流量。

兼容 Maven 和 Ivy 仓库

Gradle 兼容 POM 和 IVY 元数据格式,并且可以从任何兼容 Maven 或 IVY 的仓库检索依赖项。Ivy 元数据暴露给自定义解析规则,允许您根据工件分支、状态或其他自定义元数据信息进行过滤。

原生 BOM 支持

平台定义,也称为 Maven BOM 依赖项,受到原生支持。这使得可以导入像 Spring Boot 平台这样的定义,而无需外部插件。

动态依赖

已解析的依赖版本可以是动态的。Gradle 支持 Maven 快照机制,但比这更强大。您可以声明对最新版本、最新开发版本,甚至是最新 8.X 构建的依赖。

动态依赖锁定

允许构建在使用动态依赖版本时保持确定性和可重现性。

动态依赖选择规则

定义自定义规则,以便在声明动态依赖时选择特定版本。规则可以基于名称和版本以及扩展元数据(如分支或状态)。规则也可能因构建发生的环境而异,例如,本地或 CI。

依赖版本对齐

依赖对齐允许逻辑组中的不同模块(例如 Jackson 模块)对齐到同一版本。

版本冲突解决

Gradle 默认将冲突解析为最新的请求版本。您可以自定义此行为。

兼容库的替换

使用依赖替换规则来指定要使用的依赖项。例如,您可以指示 Gradle 通过选择 log4j 或 log4j-over-slf4j 的最新版本来解决冲突。这在依赖关系图中存在 spring-all 和 spring-core 等库的情况下特别有用。如果没有适当的管理,应用程序的行为可能会取决于脆弱的类路径顺序。

增强的元数据解析支持

您可以在 Gradle 下载仓库元数据之后,但在选择已解析版本之前调整依赖元数据。这种灵活性使得可以创建自定义规则,用于将模块声明为更改(快照)版本或使用自定义状态方案。

外部和项目依赖的替换

动态替换项目依赖的外部依赖,反之亦然。当只有您的模块的子集在本地检出时,这尤其有用。

跨团队标准化 Gradle

自我配置构建环境

使用 Gradle Wrapper,Gradle 构建环境是自动配置的。此外,您可以确定应该使用哪个版本来构建您的项目。

版本控制的构建环境配置

用于配置构建环境的重要参数可以作为项目的一部分存储在版本中。开发者无需手动设置它们。这包括要使用的 Gradle 版本、运行构建的 JVM 的配置以及运行构建的 JDK。

自定义分发

每个 Gradle 分发版都有一个 init.d 目录,您可以在其中放置预配置构建环境的自定义脚本。您可以使用它来应用强制的自定义规则,为开发者提供内置的设置任务等等。与 Gradle Wrapper 一起,您可以轻松地分发这些自定义分发版。

软件领域建模

领域对象容器

描述您构建的每个领域对象,无论是仓库、源目录、插件还是依赖项,都存储在一个响应式容器中,您可以在该容器中注册监听器。您可以完全控制特定的构建脚本向构建添加的内容。增强或修改已添加的内容,让构建失败或发出警告。例如,您可以定义仅在构建添加特定插件时才添加的依赖项。

发布多个工件

Gradle 可以为每个项目发布具有不同元数据的多个工件。无论是 API 和实现 jar、库和测试 fixtures,还是针对不同 Java 平台的变体。

高级任务排序

除了完全控制任务之间创建的依赖关系之外,Gradle 还具有强大的语言结构来描述任务之间的执行顺序,即使这些任务不依赖于彼此的输出。这可以使用 shouldRunAfter 和 mustRunAfter 关系建模。

任务依赖推断

Gradle 对象知道哪些任务生成某些内容。例如,表示 Java 二进制目录的对象知道编译任务生成二进制文件。任何以 Java 二进制目录作为输入的任务都将自动依赖于编译任务。无需手动声明。这使得构建更易于维护和更健壮。

任务 Finalizer

可以将任务分配为 finalizer 其他任务,类似于 Java 中的 finalizer 子句。这些特殊任务始终在另一个任务执行后运行,无论该任务是否失败。这在为容器或数据库执行生命周期管理时非常强大。

动态任务创建

有时您需要一个任务,其行为取决于大量或无限数值范围的参数。创建任务规则是提供此类任务的一种非常好的表达方式。

精细的构建事件监听器

Gradle 允许您挂钩到构建配置和执行生命周期的每个部分,以注入自定义行为、提取信息、添加额外的日志记录以及大量其他用例。

基于用户的行为注入

您可以将自定义监听器放入您的 Gradle 用户主目录中,这些监听器会挂钩到在您的机器上执行的每个 Gradle 构建。使用上面描述的生命周期监听器,您可以添加自定义行为来个性化您的构建体验。例如,添加和配置 Gradle announcement 插件,该插件在构建完成时弹出一个窗口,或者添加您个人使用的仓库。

每个构建的行为注入

与基于用户的行为注入类似,您可以指定额外的监听器,这些监听器会挂钩到命令行上的构建。例如,如果您希望您的 CI 构建具有特定行为(例如,如果使用非标准仓库则失败),这可能会非常有帮助。

Gradle 插件编写

TestKit 用于功能测试

通过与测试框架无关的 API 以编程方式执行构建。检查构建结果和输出。跨版本兼容性测试。从 IDE 调试被测构建。

自定义命令行选项

任务 API 支持一种机制,用于标记属性以在运行时自动生成具有特定名称的相应命令行参数。

↑ 目录

生态系统特定功能

针对 JVM、Android、C++、Swift、Objective C 和其他生态系统的特定功能。

JVM 应用程序

Java 的增量编译

无论源代码还是类路径发生更改,Gradle 都会检测到受更改影响的所有类,并且只会重新编译这些类。

Java 的编译避免

如果依赖项目以 ABI 兼容的方式更改(仅其私有 API 已更改),Java 编译任务将是最新的。

内置 Groovy 支持

Groovy 插件扩展了 Java 插件,以添加对 Groovy 项目的支持。它可以处理 Groovy 代码、混合 Groovy 和 Java 代码,甚至纯 Java 代码。

内置 Scala 支持

Scala 插件扩展了 Java 插件,以添加对 Scala 项目的支持。它可以处理 Scala 代码、混合 Scala 和 Java 代码,甚至纯 Java 代码。

内置 JVM 代码质量工具支持

Gradle 分发版包括 Checkstyle, CodeNarc, PMD, JaCoCo 和其他工具的插件。

JAR、WAR 和 EAR 的打包和分发

Gradle 开箱即用地提供了将基于 JVM 的代码打包成常见归档文件的工具。

发布到 Maven 仓库

将工件发布到 Maven 仓库,如 Bintray 或 Maven Central。

发布到 Ivy 仓库

将工件发布到具有可自定义目录布局的 Ivy 仓库。

Ant 集成

您可以深度集成任何默认、可选或自定义 Ant 任务。您还可以在运行时导入 Ant 构建,甚至部分替换依赖于 Gradle 任务的 Ant 目标。

Android 应用程序

官方 Android 构建工具

Gradle Android 插件和 Android Studio 是 Android SDK 工具团队提供和维护的官方工具。要了解有关将 Gradle 与 Android 一起使用的更多信息,请参考 Gradle 的 Android 开发者文档

原生应用程序

构建 C/C++/Obj-C/Obj-C++/汇编器

Gradle 内置支持使用汇编器、C/C++ 和 Obj-C/C++ 编译和链接程序。Gradle 可以构建共享库和静态库以及可执行文件。

本地组件的模型变体

轻松建模本地组件的变体,例如支持不同的 ABI、操作系统、构建类型等。

GCC 支持

Gradle 支持在 Linux、Windows(使用 Cygwin 和 MingW)和 Mac OS X 上使用 GCC4 进行构建。

Clang 支持

Gradle 支持在 Linux 和 Mac OS X 上使用 Clang 进行构建。

MS Visual C++ 支持

Gradle 支持在 Windows 上使用 Microsoft 的 Visual C++ 编译器进行构建。(支持 VS 2010、VS 2013 和 VS 2015)

生成 Windows 资源

Gradle 使用 Microsoft 的资源编译器将 Windows 资源脚本文件构建到您的应用程序中。

并行编译

构建本地代码时,Gradle 将编译步骤划分为可并行化的任务,并在共享资源池中执行它们。这加快了单个项目的情况,并确保 Gradle 不会在并行多项目构建中消耗过多资源。

预编译头文件

在构建软件时,Gradle 使使用预编译头文件变得容易。如果您的项目在大多数源代码中包含许多头文件,预编译头文件可以加快编译时间。预编译头文件是一种编译器特定的优化,用于缓存头文件的已解析版本。

构建混合语言二进制文件

Gradle 可以构建单独的语言(例如,汇编器和 C),并将它们链接到单个可执行文件或库中。

CUnit 测试支持

Gradle 支持使用 CUnit 测试 C 应用程序。

GoogleTest 支持

Gradle 支持使用 GoogleTest 测试 C++ 应用程序。

缓存编译

构建本地代码时,Gradle 使用构建缓存来避免重新编译未更改的代码。在重用缓存编译时,会考虑编译器参数、宏定义和头文件。

↑ 目录

面向开发者工具提供商的功能

这些功能对于在 IDE 和持续集成系统上工作的人员来说最有趣,但还有许多其他创造性的用途。

使用 Tooling API 嵌入 Gradle

用于嵌入式使用的 SDK

由 Gradle Tooling API 提供

版本无关

Gradle Tooling API 向后和向前兼容。使用特定版本的 Tooling API,您可以驱动自 1.0 以来所有 Gradle 版本的构建。

查询项目模型

您可以查询 Gradle 以获取构建的详细信息,包括项目层次结构、项目依赖项、外部依赖项(包括源和 Javadoc jar)、源目录以及每个项目中的任务。

查询构建环境信息

Gradle 提供对有关构建环境信息的编程访问。这包括有关 Gradle 版本、Gradle 用户主目录和 Java 主目录的信息。

执行构建

您可以执行构建并监听 stdout 和 stderr 日志记录和进度(例如,在命令行运行时在“状态栏”中显示的内容)。

构建操作取消

通过 Gradle Tooling API 启动的所有操作都可以在构建期间随时优雅地取消。

支持自定义 JVM 设置

通过 Gradle Tooling API 提供的 JVM 参数优先于 gradle.properties。

提供 Eclipse 项目模型

Gradle Tooling API 提供了您的项目如何映射到 Eclipse 项目的模型。

提供 IDEA 项目模型

Gradle Tooling API 提供了您的项目如何映射到 IDEA 模型的模型。

提供对自定义项目模型的支持

您可以编写 Gradle 插件来为 Gradle Tooling API 添加自定义元数据。例如,当您将自己的产品/自定义项与 Gradle 集成时,可以使用它。

运行特定测试

TestLauncher API 允许在一个或多个测试任务中运行特定的 JUnit 或 TestNG 测试。

注册进度事件

注册任务或测试进度的事件,以获取有关构建过程的信息,其中包含有关已处理任务和测试的丰富信息。

运行持续构建

Gradle Tooling API 提供了以编程方式在“持续构建”模式下运行构建的功能。构建输入中的更改(文件更改)会持续触发指定任务运行。

可自定义的日志记录

自定义日志记录模式

您可以将 Gradle 的大部分日志记录 UI 替换为您自己的。例如,如果您想以某种方式自定义 UI,例如,记录更多或更少的信息或更改格式,您可以这样做。

重定向来自其他工具的输出

构建输出对于构建用户体验非常重要。与外部工具和库集成可能会使控制台输出非常冗长。在 Gradle System.out 中,Java Util Logging、Jakarta Commons Logging 和 Log4j 的日志输出被重新路由到 Gradle 日志记录系统。您可以按工具路由和定义日志级别。

↑ 目录