参考文章:
概述
作为一个项目管理工具,maven已经流行了好多年,近几年gradle的项目慢慢多了起来,对其做一个基本的了解还是非常必要的。
两者定位相同,既然产生了gradle这个后来者,那maven有哪些不足呢?一般说来,maven的不足主要在2个方面:
1、不够简便。尤其当项目较大,依赖的jar包多的时候,pom文件会变的非常庞大,即使做了分段整理加了注释,查找起来还是感觉内容太多,有些不方便;
2、不够灵活。其实这个多数时候还好说,至少我的感受并不明显。就是maven的构建过程是严格线性的(参见文章),如果要做额外的操作,需要借助插件或者干脆自定义插件,这都是相对繁琐的;
而gradle由于grovvy语言的支持,可以做到比xml简化很多的配置文件,也可以自己灵活的控制编译打包的过程。
目标
搭建一个springboot的项目,实现controller跟service的分离依赖
构建及打包测试
spring的gradle项目,可以利用https://start.spring.io进行构建,比如:
点击Generate Project,即可下载到一个压缩包,解压导入idea,结构如下:
目录结构跟maven项目非常类似,只是原来的pom.xml替换成了settings.gradle跟build.gradle两个文件。settings主要用于设置父子模块依赖一类的配置,用于跟其它模块的交互,build则用于项目构建。
默认settings.gradle的内容只有项目名一行:rootProject.name = 'zzzgradletest'
默认build.gradle内容如下:
plugins{ id 'java' //这是个java项目,因为gradle可以构建多种语言项目 id 'org.springframework.boot' version '2.1.3.RELEASE' } apply plugin: 'io.spring.dependency-management' group 'com.study.wzy' version '1.0-SNAPSHOT' sourceCompatibility = 1.8 jar { // 打jar包的配置 baseName = 'mytest' version = '0.0.1' manifest { attributes "Manifest-Version": 1.0, 'Main-Class': 'com.study.wzy.GradletestApplication' } } repositories { //maven资源库配置 mavenLocal() //优先使用本地库,win下可以跟maven共用,mac os下未找到如何配置共用 mavenCentral() } configurations { compileOnly { //仅在编译时依赖,此处为lombok使用,相关注解在编译时生成getter、setter等 extendsFrom annotationProcessor } } dependencies { //依赖jar包,每个jar包坐标包含三个基本元素:group,name,version annotationProcessor 'org.projectlombok:lombok:1.18.6' compile group: 'org.springframework.boot', name: 'spring-boot-starter-web', version: '2.1.3.RELEASE' testCompile group: 'org.springframework.boot', name: 'spring-boot-starter-test', version: '2.1.3.RELEASE' testCompile group: 'junit', name: 'junit', version: '4.12' //testCompile 表示作用域 }
运行idea右边gradle下的build,可以生成jar包,java -jar xxx.jar 进行运行,可以访问:
示例代码:
运行jar:
访问结果
拆解项目
将项目拆为2个module,分别存放controller跟service,利用gradle设置依赖关系,并进行测试。
idea中,file -> new Module ,选择gradle跟java,next到底。创建service如下:
@Service public class TestService { public String getName(){ return "jack"; } }
web项目的启动类代码为:
@RequestMapping("/test") @RestController @SpringBootApplication public class GradletestApplication { public static void main(String[] args) { SpringApplication.run(GradletestApplication.class, args); } @Autowired private TestService testService; @RequestMapping("/mytest") public String mytest(){ return "hello " + testService.getName(); } }
在web项目,settings.gradle中引入service模块:
rootProject.name = 'zzzgradletest' includeFlat 'zzzservicetest'
在web项目的build.gradle中设置
compile project(':zzzservicetest')
引入service并进行依赖,gradle分别进行编译后就可以进行访问测试了
另:以上建立的两个模块是独立的,没有在同一个project下,因此本例中将共同的依赖放到了service中,这样web在依赖了service后会根据依赖传递,依赖到spring的相关jar。若service跟web两个module都在同一个gradle的project下,则可以将共同的配置放到project的build.gradle中,而且在new module后会自动在project的setting.gradle中生成 include 'zzzservice' 类似的代码,此时,则不用在web中配置includeFlat ‘xxxxxxx’了,includeFlat的含义是引用一个同级模块。
鉴于gradle的版本不同,有些配置也会略有区别,比如2.1及以上版本用plugins,而低版本则用apply plugin 。
暂时这样,一个简单的demo,用于熟悉gradle。