简介
本文介绍gradle的一些配置文件。包括:init.gradle, settings.gradle、
init.gradle
简介
init.gradle文件在build开始之前执行,可以在这个文件配置一些你想预先加载的操作,例如:指定仓库的地址、build日志输出,机器信息(比如jdk安装目录),build时所必需的个人信息(比如仓库或者数据库的认证信息)
启用init.gradle文件的方法
1、在命令行指定文件,例如:gradle –init-script yourdir/init.gradle -q taskName.你可以多次输入此命令来指定多个init文件
2、把init.gradle文件放到USER_HOME/.gradle/ 目录下.
3、把以.gradle结尾的文件放到USER_HOME/.gradle/init.d/ 目录下.
4、把以.gradle结尾的文件放到GRADLE_HOME/init.d/ 目录下.
如果存在上面的4种方式的2种以上,gradle会按上面的1-4序号依次执行这些文件,如果给定目录下存在多个init脚本,会按拼音a-z顺序执行这些脚本。
示例1:将慢的仓库改为阿里仓库
示例2:指定maven本地库
在build执行之前给所有的项目指定maven本地库,同时在 build.gradle文件指定了maven的仓库中心。
build.gradle
repositories {
mavenCentral()
}
task showRepos << {
println "All repos:"
println repositories.collect { it.name }
}
init.gradle
allprojects {
repositories {
mavenLocal()
}
}
在命令行输入命令:gradle –init-script init.gradle -q showRepos
执行结果
> gradle --init-script init.gradle -q showRepos
All repos:
[MavenLocal, MavenRepo]
settings.gradle
简介
settings.gradle作用就是用于多项目构建。多项目构成:allProjects = root项目+各子项目
写法
写法1:
rootProject.name = 'proj_root'
include 'proj_1'
include 'proj_2'
include 'group_A:proj_3_1'
include 'group_B:proj_4_2'
写法2:
rootProject.name = 'proj_root'
include 'proj_1', 'proj_2', 'group_A:proj_3_1', 'group_B:proj_4_2'
自定义
默认结果
假设settings.gradle这样写
rootProject.name = 'A'
include 'core', 'web', 'mobile'
运行gradle projects可得到项目结构
Root project 'A'
+--- Project ':core'
+--- Project ':mobile'
\--- Project ':web'
最终的文件以及目录结构如下所示:
A
--settings.gradle
--build.gradle
--core
--build.gradle
--web
--build.gradle
--mobile
--build.gradle
自定义:子项目与根项目的settings.gradle同级
如果不喜欢这种默认的结构,也可以按照如下方式定义子项目的名称和物理目录结构:
settings.gradle
rootProject.name = 'A'
include(':core')
project(':core').projectDir = new File(settingsDir, 'core')
include(':web')
project(':web').projectDir = new File(settingsDir, 'web')
include(':mobile')
project(':mobile').projectDir = new File(settingsDir, 'mobile')
这个例子中,子项目core实际上对应的物理目录为A/core-xxx,web实际上对应的是A/web-xxx,mobile也类似。也就是:
A
settings.gradle
build.gradle
core
build.gradle
web
build.gradle
mobile
build.gradle
虽然我们更改了子项目的物理目录结构,不过由于我们在build.gradle中使用的是类似 “ :<SubProject>”的方式访问对应的子项目,所以目录结构的改变,对我们Gradle的构建脚本并不会产生影响。
此时执行gradle projects,结果仍然是
Root project 'A'
+--- Project ':core'
+--- Project ':mobile'
\--- Project ':web'
自定义:子项目与根项目同级
如果不喜欢这种默认的结构,也可以按照如下方式定义子项目的名称和物理目录结构:
settings.gradle
rootProject.name = 'A'
include(':core')
project(':core').projectDir = new File(settingsDir, '../core')
include(':web')
project(':web').projectDir = new File(settingsDir, '../web')
include(':mobile')
project(':mobile').projectDir = new File(settingsDir, '../mobile')
这个例子中,子项目core实际上对应的物理目录为core,web实际上对应的是web,mobile也类似。即:
A
settings.gradle
build.gradle
core
build.gradle
web
build.gradle
mobile
build.gradle
虽然我们更改了子项目的物理目录结构,不过由于我们在build.gradle中使用的是类似 “ :<SubProject>”的方式访问对应的子项目,所以目录结构的改变,对我们Gradle的构建脚本并不会产生影响。
此时执行gradle projects,结果仍然是
Root project 'A'
+--- Project ':core'
+--- Project ':mobile'
\--- Project ':web'
gradle.properties
用途
可以自定义某些自定义设置。如 :依赖的版本(如SpringBoot)、JVM 内存设置,Java home,守护进程的开/关等。
这些配置将会按以下顺序被应用(以防在多个地方都有配置时只有最后一个 生效):
- 位于项目构建目录的gradle.properties。
- 位于gradle 用户主目录的gradle.properties。
- 系统属性,例如当在命令行中使用 -Dsome.property 时。
实例
gradle.properties
lombokVersion = '1.18.10'
build.gradle
dependencies {
compile("org.projectlombok:lombok:${lombokVersion}")
}
其他设置属性的方法
命令行中通过-D
或者-P
给Gradle实时创建属性。
-D
属性会被传送给启动Gradle的jvm,作为一个系统属性被jvm使用。
build.gradle
task hello << {
println "hello, $guestName"
}
命令行执行结果
$ gradle hello -DguestName='Bowen' -q
Bowen
-P
属性则会被直接加载到Gradle领域对象上。
build.gradle
task hello << {
println "hello, $guestName"
}
命令行执行结果
$ gradle hello -PguestName='Bowen' -q
hello, Bowen
如果有systemProp.
前缀的属性会被识别为系统属性。
gradle.properties
systemProp.guestName = 'Bowen'
build.gradle
task hello << {
println "hello, " + System.properties['guestName']
}
命令行执行结果
$ gradle hello -q
hello, Bowen
将特殊前缀的系统属性或环境变量自动加入到Gradle领域对象中。
如果有环境变量以ORG_GRADLE_PROJECT.为前缀,那么该变量会被自动添加到Gradle领域对象中。如果有系统属性以org.gradle.project.为前缀,那么也会被自动加入到Gradl领域对象中。这一特性的目的之一是为了隐藏一些敏感的信息。比如在执行Gradle脚本时需要传入密码信息,如果以-P的方式传送会被别人看到。而把该属性保存为环境变量,只有系统管理员才有权访问和修改。在运行Gralde的时候该环境变量会被自动加入到Gradle对象中被使用,隔离了明暗数据,又不行影响其他用户使用。(其他用户可以通过-P方式设置该属性)。
build.gradle
task hello << {
println "hello, " + guestName
}
命令行执行结果
$ gradle hello -Dorg.gradle.project.guestName=Bowen -q
hello, Bowen
$ export ORG_GRADLE_PROJECT_guestName=Bob
$ gradle hello -q
hello, Bob
gradle-wrapper.properties
为什么需要Gradle Wrapper
若每个成员都在电脑中安装Gradle,这时运行Gradle的环境和版本就会对构建结果带来不确定性。
Gradle Wrapper就是此问题的解决方案。Gradle Wrapper是对Gradle的一层包装,它是一个脚本,可自动下载安装Gradle,运行Gradle构建,且能指定Gradle版本,这样就标准化了项目。Idea在新建项目时会自带Gradle Wrapper。
相关命令
Idea在创建项目时,会执行gradle wrapper命令,生成以下文件
|____gradle
| |____wrapper
| | |____gradle-wrapper.jar //具体业务逻辑
| | |____gradle-wrapper.properties //配置文件
|____gradlew //Linux 下可执行脚本
|____gradlew.bat //Windows 下可执行脚本
终端执行gradle wrapper生成相关文件时,可指定如下参数,控制wrapper的生成:
Wrapper配置参数:
--gradle-version 用于指定使用的Gradle版本
--gradle-distribution-url 用于指定下载Gradle发行版的url地址
例如:gradle wrapper --gradle-version 4.1
表示配置 wrapper使用4.1版本Gradle,文件gradle-wrapper.properties中的distributionUrl的规则是http\://services.gradle.org/distributions/gradle-${gradleVersion}-bin.sip。若不设置,则会默认使用当前安装的Gradle版本。
当使用Gradle Wrapper启动Gradle时,如果指定版本的Gradle没有被下载关联,会先从distributionUrl下载该版本Gradle到用户本地,进行解包并执行批处理文件。后续的构建运行都会重用这个解包的运行时安装程序。
gradle-wrapper.properties说明
gradle-wrapper.properties:
distributionBase=GRADLE_USER_HOME
distributionPath=wrapper/dists
distributionUrl=https\://services.gradle.org/distributions/gradle-5.2.1-bin.zip
zipStoreBase=GRADLE_USER_HOME
zipStorePath=wrapper/dists
- distributionBase:Gradle解包后存储的主目录。
对于Idea,是:File=>Settings=> Build,Execution,Deployment=> Build Tools=> Gradle=> Gradle user home - distributionPath:distributionBase指定目录的子目录。
distributionBase+distributionPath就是Gradle解包后的存放位置。 - distributionUrl:Gradle发行版压缩包的下载地址。
- zipStoreBase:Gradle压缩包存储主目录。
- zipStorePath:zipStoreBase指定目录的子目录。
zipStoreBase+zipStorePath就是Gradle压缩包的存放位置。