GradleWrapper、命令行和环境配置

前言

这三个知识点不难,但经常用到,如果不看官方文档,有时候并不知道怎么使用,出现问题也不知道原因,所以有必要做一个总结。由于每个知识点都不多,又有关联,所以放在同一节。

Gradle Wrapper

Gradle Wrapper(以下简写为“Wrapper”)用于管理当前项目的Gradle版本,Gradle官方强烈推荐使用Wrapper构建项目。多人协作时,必须规定项目的Gradle版本,并以此版本的Gradle作为项目的构建工具,由于每个人在本地安装的Gradle版本可能并不一致(也没有必要一致),因此有必要在项目中统一管理Gradle版本。

Wrapper的文件结构如下(项目根目录中):

├── build.gradle
├── settings.gradle
├── gradle
│   └── wrapper
│       ├── gradle-wrapper.jar
│       └── gradle-wrapper.properties
├── gradlew
└── gradlew.bat

包括一个gradle文件和两个可执行的脚本文件gradlew(macOS等平台用)和gradlew.bat(Windows平台用)。

  • gradle-wrapper.jar。用于下载所需版本的Gradle。
  • gradle-wrapper.properties。配置Gradle的版本号、本地存储地址等。各属性说明请见官方文档
  • gradlew, gradlew.bat。Wrapper的执行脚本,用于替代gradle命令来构建项目。

注意:gradle-wrapper.properties中有一个distributionUrl属性,用于定义Gradle版本地下载URL,如distributionUrl=https\://services.gradle.org/distributions/gradle-4.0-all.zip,版本号后面有个“-all”,有时你也可能看到“-bin”,是什么意思呢?"-all"表示会下载此版本Gralde的所有的资源,包括二进制运行时文件、示例代码和相关文档。“-bin”表示只下载二进制运行时文件。

Wrapper 构建项目时,其工作流程如下:

  1. 检查规定的Gradle版本,如果没有则去服务器下载。
  2. 下载的Gradle版本存储在Gradle的用户目录中。如macOS中默认存储所有的Gradle版本到/Users/yourname/.gradle/wrapper/dists/中。
  3. 使用解压后的Gradle版本来构建项目。
wrapper workflow

添加Wrapper

使用命令行添加Wrapper有两种方式:

  1. 使用gradle init创建新项目,则会初始化一个带有Wrapper的Gradle项目。
  2. 使用gradle wrapper在旧的项目中添加Wrapper。

wrapper是Gradle的内建任务

一般的IDE创建项目时都会自动生产Wrapper文件,如Android Studio。

使用Wrapper执行任务

用Wrapper脚本替换掉gradle来执行任务即可。以macOS平台为例,在项目根目录下执行./gradlew [task name]即可,如列出当前项目的所有任务,项目根目录下执行:

$ ./gradlew tasks

更新Wrapper

有两种方式更新Wrapper

  1. 命令行方法。.gradlew wrapper --gradle-version [要更新的版本号]
  2. 修改gradle/wrapper/gradle-wrapper.properties中的distributionUrl属性。


Gradle命令行

与Gradle交互有两种方式,一是命令行界面,二是IDE的图形界面,如Android Studio。IDE方式各有不同且未必包括所有的命令行指令,但命令行方式却是不变的,因此需要学会基本的命令行指令,以不变应万变。

注意:在项目中使用命令行方式时,推荐使用./gradlew or gradlew.bat 来代替 gradle。示例中为了方便,统一使用gradle

命令行指令可以自定义,参见declaring_and_using_command_line_options

指令形式

gradle [taskName...] [--option-name...]

说明

  • 任务名(taskName)有多个时,使用空格分开,如gradle task1 task2

  • 在多项目工程中,执行某个项目的任务时,可以用“:”将项目名添加到任务名之前,如

    $ gradle projectName:taskName
    $ gradle :projectName:taskName
    
  • 可选项(option-name)如果接收参数,建议使用=拼接,如

    $ gradle task1 --console=plain
    
  • 可选项规定一个行为时,可使用--no-作为其全称(long-form)前缀,来指定它的对立行为。如

    --build-cache
    --no-build-cache
    
  • 可选项的全称名称常有简写形式 ,如

    --help
    -h
    

常见内建(built-in)任务指令

  • gradle build。生成所有的输出,并执行所有的检查。
  • gradle run。生成应用程序并执行某些脚本或二进制文件
  • gradle check。执行所有检测类任务如tests、linting等
  • gradle clean。删除build文件目录。
  • gradle projects。查看项目结构。
  • gradle tasks。查看任务列表。查看某个任务详细信息,可用gradle help --task someTask
  • gradle dependencies。查看依赖列表。

部分常见命令行选项说明如下:

调试类

  • -?, -h, --help。查看帮助信息。
  • -v,--version。查看版本信息。
  • -s,--stacktrace。执行任务时,打印栈信息。如gradle build --s

其他选项说明见官方文档Debugging options

日志类

  • -q, --quiet。只打印errors类信息。
  • -i, --info。打印详细的信息。

其他选项说明见官方文档Logging options,更多关于日志类描述请见Logging

性能类

用于优化构建的性能

  • --configure-on-demand,--no-configure-on-demand。是否开启按需配置模式。
  • --build-cache, --no-build-cache。是否使用缓存。

其他选项说明见官方文档Performance Options,更多关于性能优化方面的描述请见 improving performance of Gradle builds here.

环境配置类

用于配置构建时的环境

  • -c, --settings-file。如果不用默认的settings.gradle时,可指定Setting文件。
  • -b, --build-file。指定构建文件。
  • -Dorg.gradle.jvmargs。设置JVM参数。

其他选项说明见官方文档Environment options,更多关于环境配置方面的描述请见build environment


环境配置

配置构建环境,主要配置Gradle构建参数和对应的JVM参数,如代理策略等。其目的是为了多人协作时,保持在一致的环境下进行项目开发。

配置环境有几种途径,优先级从高往低,列出如下:

  1. 命令行。
  2. GRADLE_USER_HOME目录中的gradle.properties文件。
  3. 项目根目录中的gradle.properties文件。
  4. 环境变量。运行Gradle环境的变量,如JAVA_HOME等。

配置环境其实是设置各种属性参数,以上四种方式对于某些属性都可以配置。其中命令行和gradle.properties文件方式支持所有属性的配置。属性有不同的级别,按照优先级从高到底列出如下:

  1. 系统属性(System properties)。
  2. Gradle属性。

系统属性

用于设置Gradle的JVM环境。

  1. 命令行方式。通过给属性添加-D前缀来设置。如gradle -Dgradle.user.home=foo
  2. gradle.properties文件方式。根目录中,为属性添加systemProp.前缀,如systemProp.gradle.wrapperUser=myuser

几个系统属性如下:

  • gradle.wrapperUser=(myuser)。设置Wrapper下载Gradle版本的代理服务器的用户名。
  • gradle.wrapperPassword=(mypassword)。设置Wrapper下载Gradle版本的代理服务器的密码。
  • gradle.user.home=(path to directory)。设置Gradle用户目录地址。

Gradle属性

Gradle属性都有对应的命令行方式,gradle.properties文件属性和对应的命令行如下:

gradle.properties文件属性 命令行指令
org.gradle.caching=(true,false) --build-cache, --no-build-cache
org.gradle.caching.debug=(true,false) ?
org.gradle.configureondemand=(true,false) --configure-on-demand, --no-configure-on-demand
org.gradle.console=(auto,plain,rich,verbose) --console=(auto,plain,rich,verbose)
org.gradle.daemon=(true,false) --daemon, --no-daemon
org.gradle.daemon.idletimeout=(# of idle millis) -Dorg.gradle.daemon.idletimeout=(number of milliseconds)
org.gradle.debug=(true,false) -Dorg.gradle.debug=(true,false)
org.gradle.java.home=(path to JDK home) -Dorg.gradle.java.home
org.gradle.jvmargs=(JVM arguments) -Dorg.gradle.jvmargs
org.gradle.logging.level=(quiet,warn,lifecycle,info,debug) -Dorg.gradle.logging.level=(quiet,warn,lifecycle,info,debug)或者 -q-w-i-d
org.gradle.parallel=(true,false) --parallel, --no-parallel
org.gradle.warning.mode=(all,none,summary) -Dorg.gradle.warning.mode=(all,none,summary) 或者--warning-mode=(all,none,summary)
org.gradle.workers.max=(max # of worker processes) --max-workers

详细说明请见Gradle properties

另外官网中有项目属性和通过项目属性配置任务的说明,这里不做描述,请见官网Project properties

示例-设置JVM参数

对于每个Java虚拟机进程,Gradle默认配置堆空间最大为1024MB(-Xmx1024m)。-Xmx1024m根据项目大小,可以修改这一参数。如果使用了Gradle Daemon(org.gradle.daemon=true,默认开启),则配置参数如下:

org.gradle.jvmargs=-Xmx2g -XX:MaxPermSize=256m -XX:+HeapDumpOnOutOfMemoryError -Dfile.encoding=UTF-8

Java虚拟机参数设置参考Java HotSpot VM Options:Java 8及以上Java 7参考。上面的参数说明如下:

  • -Xmx[size]。设置虚拟机最大内存空间。必须是1024的倍数,且不能小于2MB,单位为k/K、m/M、g/G,默认值随系统配置而变。与XX:MaxHeapSize等价。示例80MB:

    -Xmx83886080
    -Xmx81920k
    -Xmx80m
    
  • -XX:MaxPermSize=[size]。设置持久代最大空间,持久代用于存储常量等,如果报java.lang.OutOfMemoryError: PermGen space的异常,则需要增加这一空间。

    Java虚拟机内存划分请见Oracle官方文档Generations

  • -XX:-HeapDumpOnOutOfMemoryError。当抛出java.lang.OutOfMemoryError异常时,将堆内容存储到文件中,用于调试。

  • -Dfile.encoding=UTF-8。虚拟机编码格式。

    在参考文档中并没有找到``-Dfile.encoding`设置

示例-设置代理

国内下载依赖和Google资源时有时候速度很慢,可以通过设置HTTP和HTTPS代理服务解决。在gradle.properties中设置如下:

# http代理
systemProp.http.proxyHost=www.somehost.org
systemProp.http.proxyPort=8080
systemProp.http.proxyUser=userid
systemProp.http.proxyPassword=password
systemProp.http.nonProxyHosts=*.nonproxyrepos.com|localhost

# https代理
systemProp.https.proxyHost=www.somehost.org
systemProp.https.proxyPort=8080
systemProp.https.proxyUser=userid
systemProp.https.proxyPassword=password
systemProp.https.nonProxyHosts=*.nonproxyrepos.com|localhost

如果没有user和password,可以不用写。

其他的代理参数可以参考Java文档Networking Properties


参考

  1. Gradle官网-Gradle Wrapper
  2. Gradle官网-Command-Line Interface
  3. Gradle官网-Build Environment
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,294评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,780评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,001评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,593评论 1 289
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,687评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,679评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,667评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,426评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,872评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,180评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,346评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,019评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,658评论 3 323
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,268评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,495评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,275评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,207评论 2 352

推荐阅读更多精彩内容