@dume2007
2017-02-28T16:03:48.000000Z
字数 4606
阅读 2937
java
gradle
Groovy
maven
spring
Gradle 是一款基于 Groovy 语言、免费开源的构建工具,它既保持了 Maven 的优点,又通过使用 Groovy 定义的 DSL
克服了 Maven 中使用 XML 繁冗以及不灵活的缺点。
Gradle 官方网站:http://www.gradle.org/downloads
一种方式是从 官方 下载解压然后配置环境变量。
$ brew install gradle
Chocolatey是windows下的包管理器
C:\> choco install gradle
wget https://services.gradle.org/distributions/gradle-3.4-bin.zip
mkdir /opt/gradle
unzip -d /opt/gradle gradle-3.4-bin.zip
export PATH=$PATH:/opt/gradle/gradle-3.4/bin
测试是否安装成功:
$ gradle -v
Gradle 2.0 Build time: 2014-07-01 07:45:34 UTC
Build number: none
Revision: b6ead6fa452dfdadec484059191eb641d817226c
Groovy: 2.3.3
Ant: Apache Ant(TM) version 1.9.3 compiled on December 23 2013
JVM: 1.7.0_60 (Oracle Corporation 24.60-b09)
OS: Mac OS X 10.9.4 x86_64
Gradle 使用 约定优于配置(Convention over Configuration)的理念。使用与maven兼容的目录结构布局。完全按照约定的目录结构来布置工程文件,会大大简化编译配置文件。
除了常见的src/main/java
等目录,默认的 web 应用程序根目录为 src/main/webapp
,也就是包含 WEB-INF 目录的上一级目录。如果工程没有完全依照约定布局,可以通过脚本文件指定相应的路径。
Gradle 中有两个最基本的对象:project
和 task
。每个 Gradle 的构建由一个 project 对象来表达,它代表着需要被构建的组件或者构建的整个项目。每个 project 对象由一个或者多个 task 对象组成。
Gradle 已经自带了很多 pugins,可以满足大部分的常见构建任务。
Gradle 的默认构建脚本文件为工程根目录下的 build.gradle
。
作为测试,创建一个 test 目录,然后通过下面命令来初始化一个项目:
$ mkdir test
$ cd test
$ gradle init
:wrapper
:init
BUILD SUCCESSFUL
Total time: 3.058 secs
$ ls
build.gradle gradle gradlew gradlew.bat settings.gradle
可以看到生成了 gradle 的一些配置文件。接下来在 build.gradle
文件中添加下面代码,可以支持生成 jar 包:
apply plugin: 'java'
这就是你定义一个Java项目所需要做的一切。这就会在你项目里使用Java插件,该插件会给你的项目增加很多任务。
Gradle 期望在 src/main/java
路径下找到你项目的源代码,并且测试在 src/test/java
路径下的代码。同时,在src/main/resources
路径下的文件也会作为资源文件包含在JAR包中,并且 src/test/resources
下的所有文件会包含在 classpath下以运行测试程序。所有的输出文件都生成在 build 目录下,JAR 包生成在 build/libs
目录下。
运行下面命令即可生成 jar 包:
$ gradle jar
# 如果 jar 包中有一个包含 main 方法的主类,想让其打包之后能够运行其 main 方法,则需要添加下面代码:
apply plugin: 'java'
jar {
manifest {
attributes 'Main-Class': 'com.javachen.gradle.HelloWorld'
}
}
通常,JAR 包需要被发布到某个地方。为了完成这个功能,你需要告诉 Gradle 把 JAR 包发布到哪里。在 Gradle 中,如 JAR 之类的压缩包都被发布到库中。在我们的样例中,我们将会发布到本地仓库。你也可以发布到一个或多个远端地址。
发布 jar 包添加如下配置:
uploadArchives {
repositories {
flatDir {
dirs 'repos'
} }
}
此外,你还可以添加下面代码,引入 Eclipse 插件以支持生成 Eclipse 工程:
apply plugin: 'eclipse'
#添加Maven库:
repositories {
mavenCentral()
}
#如果想添加依赖,也是非常简单,例如添加 spring 依赖:
apply plugin: 'java'
dependencies {
compile 'org.springframework:spring-context:3.2.6.RELEASE'
testCompile group: 'junit', name: 'junit', version: '4.+'
}
gradle 便会自动地到 maven 服务器下载 spring-context-3.2.6.RELEASE.jar,以及它所依赖的 jar 包。
常用的依赖:
(1)compile:编译生产代码的依赖环境,即src/main/下
(2)runtime:生产代码运行时的依赖(包含编译生产代码时的依赖)
(3)testCompile:编译测试代码的依赖环境,即src/test下
(4)testRuntime:测试代码运行时的依赖(包含编译测试代码时的依赖)
当然,也可以直接依赖本地的 jar 包,例如:
apply plugin: 'java'
dependencies {
compile fileTree(dir: 'libs', include: '*.jar')
}
#也可以通过 buildscript{} 中添加依赖的方式,将相关 jar 包加入到 classpath 中,如:
buildscript {
repositories {
mavenCentral()
}
dependencies {
classpath group: 'commons-codec', name: 'commons-codec', version: '1.2'
}
}
综上,完成的配置如下:
apply plugin: 'java'
apply plugin: 'eclipse'
jar {
manifest {
attributes 'Main-Class': 'com.javachen.gradle.HelloWorld'
}
}
repositories {
mavenLocal()
mavenCentral()
mavenRepo urls: "http://repository.sonatype.org/content/groups/forge/"
}
dependencies {
compile 'org.springframework:spring-context:3.2.6.RELEASE'
testCompile group: 'junit', name: 'junit', version: '4.+'
compile fileTree(dir: 'libs', include: '*.jar')
}
buildscript {
repositories {
mavenLocal()
mavenCentral()
mavenRepo urls: "http://repository.sonatype.org/content/groups/forge/"
}
dependencies {
classpath group: 'commons-codec', name: 'commons-codec', version: '1.2'
}
}
uploadArchives {
repositories {
flatDir {
dirs 'repos'
}
}
}
gradle 不像 maven 那样有固定的项目结构,gradle 原声 API 是不支持的,要想做到这一点,我们可以自定义一个 task。
apply plugin: 'idea'
apply plugin: 'java'
apply plugin: 'war'
task createJavaProject << {
sourceSets*.java.srcDirs*.each { it.mkdirs() }
sourceSets*.resources.srcDirs*.each { it.mkdirs()}
}
task createWebProject(dependsOn: 'createJavaProject') << {
def webAppDir = file("$webAppDirName")
webAppDir.mkdirs()
}
然后运行下面命令:
$ gradle createJavaProject
另外,还可以使用 gradle templates 创建项目目录结构,这里不做研究。
更加标准的方法是使用 gradle 自带的插件创建项目目录结构,例如创建 java 项目结构:
$ gradle init --type java-library
这时候的目录结果如下:
$ tree -L 4
.
├── build.gradle
├── gradle
│ └── wrapper
│ ├── gradle-wrapper.jar
│ └── gradle-wrapper.properties
├── gradlew
├── gradlew.bat
├── settings.gradle
└── src
├── main
│ └── java
│ └── Library.java
└── test
└── java
└── LibraryTest.java
7 directories, 8 files
如果想要导入到 idea 中,先执行下面命令:
$ gradle idea
这时候的 build.gradle 如下:
apply plugin: 'idea'
apply plugin: 'java'
apply plugin: 'war'
task createJavaProject << {
sourceSets*.java.srcDirs*.each { it.mkdirs() }
sourceSets*.resources.srcDirs*.each { it.mkdirs()}
}
task createWebProject(dependsOn: 'createJavaProject') << {
def webAppDir = file("$webAppDirName")
webAppDir.mkdirs()
}
如何将一个 java 项目从maven迁移到 gradle 呢?gradle 集成了一个很方便的插件:Build Init Plugin
,使用这个插件可以很方便地创建一个新的 gradle 项目,或者将其它类型的项目转换为 gradle 项目。
要将 maven 项目转换为 gradle 项目,只需要在项目的 pom 文件所在的目录下执行以下命令:
$ gradle init --type pom
上面的命令会根据 pom 文件自动生成 gradle 项目所需的文件和配置,然后以 gradle 项目重新导入即可。