Gradle 安装配置

Gradle 官方网站为 https://gradle.org,当前(2023-06-03)最新稳定版本为 v8.1.1。

安装 Gradle 前请先保证本地已经安装好了 Java8+ 的 JDK 或 JRE,可执行如下命令确认:

$ java -version
# 有输出相应的 java 版本信息就证明已预先安装了 Java。
如我安装的是 Java17:
openjdk version "17.0.2" 2022-01-18
OpenJDK Runtime Environment Temurin-17.0.2+8 (build 17.0.2+8)
OpenJDK 64-Bit Server VM Temurin-17.0.2+8 (build 17.0.2+8, mixed mode, sharing)

1. 下载 zip 安装包

Gradle 各个版本的官方下载地址为 https://services.gradle.org/distributions,Gradle 的安装包是各个平台通用的(Windows、macOS、Linux),稳定版的发布包有好几个,命名格式为:

  • gradle-{version}-all.zip - 运行时 + 文档 + 源码
  • gradle-{version}-bin.zip - 运行时
  • gradle-{version}-docs.zip - 文档
  • gradle-{version}-src.zip - 源代码

使用 gradle 开发只需安装 gradle-{version}-bin.zip,文档和源码在线查即可,如 gradle-8.1.1-bin.zip 的下载地址为 https://services.gradle.org/distributions/gradle-8.1.1-bin.zip。

2. 解压安装

将下载的 gradle-{version}-bin.zip 安装包解压,解压后目录结构如下:

/path-to/gradle-{version}/
  ├── bin/
  │   ├── gradle
  │   └── gradle.bat
  ├── init.d/
  │   └── readme.txt
  ├── lib/
  │   ├── plugins/
  │   │   └── *.jar
  │   ├── gradle-wrapper-shared-{version}.jar
  │   └── *.jar
  ├── LICENSE
  ├── NOTICE
  └── README

为了方便日后升级更新,在与 gradle-{version} 同级目录下创建一个目录 gradle 软连接到目录 gradle-{version}

Windows: (以管理员身份执行 CMD)

> cd /path-to/gradle-8.1.1
> mklink /D gradle gradle-8.1.1
为 gradle <<===>> gradle-8.1.1 创建的符号链接

macOS 或 Linux:

$ cd /path-to/gradle-8.1.1
$ ln -s gradle-8.1.1 gradle
$ ls -l
... gradle -> gradle-8.1.1

下次升级 gradle,只需解压新版本到同级目录,然后删除软连接 gradle 并重新链接到新版本的目录即可。

3. 配置系统环境变量

将 Gradle 安装路径 /path-to/gradle/bin 添加到系统环境变量 PATH 内,这样就可以在命令行直接执行 gradel 命令。

Windows 环境打开系统属性窗口(如命令行执行 sysdm.cpl),切换到 "高级" 页签,然后点击 "环境变量(N)..." 按钮,然后将 /path-to/gradle/bin 添加到 Path 变量值的后面即可。

Linux 或 MacOS 环境建议修改 /etc/profile 文件添加如下一行:

export PATH=$PATH:/path-to/gradle/bin

其它环境变量:(非必须的,按需配置即可)

  1. GRADLE_USER_HOME - 当执行 gradle 任务,gradle 会自动下载项目依赖的 jar 文件,默认这些文件缓存在系统用户目录下,目录名为 $USER_HOME/.gradle,对于用户目录所在分区容量有限的情况下,就必须迁移到其它分区,迁移方法很简单,添加系统环境变量 GRADLE_USER_HOME,指向其它分区的特定目录即可。该目录的基本结构为:
    ├── caches                 # 1
    │   ├── 4.8                # 1.1
    │   ├── 4.9                # 1.1
    │   ├── ⋮
    │   ├── jars-3             # 1.2
    │   └── modules-2          # 1.2
    ├── daemon                 # 2
    │   ├── ⋮
    │   ├── 4.8
    │   └── 4.9
    ├── init.d                 # 3
    │   └── my-setup.gradle
    ├── wrapper
    │   └── dists              # 4
    │       ├── ⋮
    │       ├── gradle-4.8-bin
    │       ├── gradle-4.9-all
    │       └── gradle-4.9-bin
    └── gradle.properties      # 5
    
    • 1 - Gradle 全局缓存目录(所有非项目特定的东西都缓存在这个目录下)
    • 1.1 - Gradle 特定版本的缓存(如用于支持增量构建)
    • 1.2 - Gradle 共享缓存(如项目依赖的 jar 包)
    • 2 - Gradle Daemon 的 Registry 和 logs
    • 3 - Gradle 全局初始化脚本
    • 4 - 通过 Gradle Wrapper 下载的安装包
    • 5 - Gradle 全局属性配置

    这些目录下缓存的内容,会由 Gradle 控制自动清除,清除规则请参考 Gradle 官方文档的说明。

  2. 通过设置环境变量 GRADLE_OPTS 控制 java 运行参数,详见这里。

4. 验证安装

> gradle -v
Welcome to Gradle 8.1.1!

Here are the highlights of this release:
 - Stable configuration cache
 - Experimental Kotlin DSL assignment syntax
 - Building with Java 20
For more details see https://docs.gradle.org/8.1.1/release-notes.html

------------------------------------------------------------
Gradle 8.1.1
------------------------------------------------------------
Build time:   2023-04-21 12:31:26 UTC
Revision:     1cf537a851c635c364a4214885f8b9798051175b

Kotlin:       1.8.10
Groovy:       3.0.15
Ant:          Apache Ant(TM) version 1.10.11 compiled on July 10 2021
JVM:          17.0.2 (Eclipse Adoptium 17.0.2+8)
OS:           Windows 11 10.0 amd64

看到上述输出的版本号信息就证明安装成功。

5. 更新 Gradle Wrapper

如果现存的某些项目是使用 Gradle Wrapper 来构建项目的,可以简单的使用下面的命令升级 gradle 到特定的版本:

$ ./gradlew wrapper --gradle-version=8.1.1 --distribution-type=bin

执行上述命令后,下次通过 gradlewgradlew.bat 执行 gradle task 时,Gradle 就会自动下载特定的 gradle 版本进行更新:

$ ./gradlew tasks
Downloading https://services.gradle.org/distributions/gradle-8.1.1-bin.zip

6. 配置镜像加速

gradle 下载的依赖包,默认国内一般下载速度很慢,故需要全局配置一下 gradle,使其默认从其它高速的镜像源下载依赖包,告别龟速。

配置方法为在 $GRADLE_USER_HOME 目录下创建 init.gradle 文件,添加如下内容:

// 自定义默认的 maven 仓库列表
def CUSTOM_REPOSITORIES = {
  // 内网的 nexus 服务,如 http://192.168.0.x:8081/repository/maven-public
  maven { url "$内网Nexus服务地址" }

  // 阿里镜像: central 和 jcenter 的聚合仓库 http://jcenter.bintray.com 和 https://repo1.maven.org/maven2
  //maven { url "https://maven.aliyun.com/repository/public" }
  // 阿里镜像: google 仓库 https://maven.google.com/
  //maven { url "https://maven.aliyun.com/repository/google" }
  // 阿里镜像: gradle-plugin 仓库 https://plugins.gradle.org/m2/
  //maven { url "https://maven.aliyun.com/repository/gradle-plugin" }

  // 原始的非镜像
  //google()
  //jcenter()
  //central()
}

allprojects {
  // 配置项目依赖的下载源
  repositories CUSTOM_REPOSITORIES

  // 配置 gradle 插件依赖的下载源
  buildscript.repositories CUSTOM_REPOSITORIES
}

相关仓库地址按需配置即可,上述只是提供一个配置模板,将速度最快的配置在最前面即可。

参考

  • Gradle docs / Installing Gradle
  • Gradle docs / The Directories and Files Gradle Uses - 解析 Gradle 全局缓存目录结构及特定项目的目录结构
  • Gradle docs / Initialization Scripts

你可能感兴趣的:(Gradle 安装配置)