标签:ogr 本地库 file dev overflow 缺点 参考 trace 子项目
目录 start
目录 end
|2018-08-03| 码云 | CSDN | OSChina
****************************************
个人看法
优缺点
优点
缺点
Gradle in Action 中译
如果没有一点Groovy基础, 阅读自定义Task等一些高自定义的地方还是比较困惑
官方网址 有各个版本的下载以及版本发行说明
似乎版本越高,内存占用越大, 从4.7降级回了4.2
4.6
发行说明 |
支持Junit5, 还有解决依赖冲突的一种声明式方式
和maven使用同一个本地库 只要加上 M2_HOME 环境变量即可, 值和 MAVEN_HOME 一样, 并没有用
curl -s "https://get.sdkman.io" | bash
sdk install gradle
即可安装wr https://chocolatey.org/install.ps1 -UseBasicParsing | iex
set-executionpolicy remotesigned
后脚本顺利执行gradle 构建文件中的task名
: 直接运行task-b,--build-file test.gradle
指定运行脚本文件--offline
离线模式-P ,--project-prop
:配置参数 -Pmyprop=value-i,--info
: 打印info级别的输出-s,--stacktrace
: 输出错误栈-q,--quiet
:减少构建出错时打印的错误信息tasks
: 输出所有建立的taskproperties
: 输出所有可用的配置属性--daemon
就会开启一个守护进程,只会开启一次,gadle --stop
--no--daemon
阿里云
当前项目的build.gradle
repositories {
def aliyun = "http://maven.aliyun.com/nexus/content/groups/public/"
def abroad = "http://central.maven.org/maven2/"
maven {
url = aliyun
artifactUrls abroad
}
// 马云上自己的库
maven {
url = "https://gitee.com/gin9/MavenRepos/raw/master"
}
mavenCentral()
jcenter()
}
全局的配置
~/.gradle/init.gradle
allprojects{
repositories {
def ALIYUN_REPOSITORY_URL = ‘http://maven.aliyun.com/nexus/content/groups/public‘
def ALIYUN_JCENTER_URL = ‘http://maven.aliyun.com/nexus/content/repositories/jcenter‘
all { ArtifactRepository repo ->
if(repo instanceof MavenArtifactRepository){
def url = repo.url.toString()
if (url.startsWith(‘https://repo1.maven.org/maven2‘)) {
project.logger.lifecycle "Repository ${repo.url} replaced by $ALIYUN_REPOSITORY_URL."
remove repo
}
if (url.startsWith(‘https://jcenter.bintray.com/‘)) {
project.logger.lifecycle "Repository ${repo.url} replaced by $ALIYUN_JCENTER_URL."
remove repo
}
}
}
maven {
url ALIYUN_REPOSITORY_URL
url ALIYUN_JCENTER_URL
}
}
}
Hello World
task helloworld{
doLast {
printf ‘Hello World!‘
}
}
// 或者是 使用 << 代表doLast:
task helloworld<<{
println ‘Hello world!‘
}
gradle -q helloworld
使用本地依赖 compile files(‘lib/ojdbc-14.jar‘)
相对的根目录是src同级目录
新建一个文件 dependency.gradle
ext {
ver = [
junit : ‘4.12‘,
]
libs = [
"junit" : "junit:junit:$ver.junit",
]
}
apply from: ‘dependency.gradle‘
compile libs[‘junit‘]
即使在子模块中也是如此使用在使用IDE生成项目的时候,可以选择gradle的执行目录,可以选
gradle wrapper
也可以选自己下载解压的完整包
如果使用的不是这个wrapper,那么别人在下载项目后,运行gradle命令就要先安装gradle,使用wrapper更好
task wrapper(type: Wrapper){
gradleVersion = ‘4.8‘
distributionUrl = ‘限定访问内网的URL‘
distributionPath = ‘包装器被解压缩放的相对路径‘
}
gradle wrapper --gradle-version 2.0
有多种方式:
// 1
apply plugin: ‘java‘
// 2
apply{
‘java‘
}
// 3
plugins{
id ‘java‘
}
lombok
annotationProcessor ‘org.projectlombok:lombok:1.18.2‘
compileOnly ‘org.projectlombok:lombok:1.18.2‘
testAnnotationProcessor ‘org.projectlombok:lombok:1.18.2‘
testCompileOnly ‘org.projectlombok:lombok:1.18.2‘
apply plugin: "maven"
然后就能执行 install等命令了shadowJar 含依赖的jar进行打包
apply plugin: ‘docker‘
classpath(‘se.transmode.gradle:gradle-docker:1.2‘)
项目的配置信息, 一般存在这个文件的时候, Gradle就会认为当前目录是作为一个完整的根项目的, 并在当前目录添加 .gradle 目录
一般默认内容为rootProject.name = ‘‘
采用一个文件统一管理依赖, 然后各个子项目独立引用 | 完整示例 JavaBase
统一配置依赖, 管理多模块
如果要添加一个项目也简单
参考博客:重拾后端之Spring Boot(六) -- 热加载、容器和多项目
直接在build.gradle中配置
// 一个典型的根项目的构建文件结构
buildscript {
// 构建脚本段落可以配置整个项目需要的插件,构建过程中的依赖以及依赖类库的版本号等
}
allprojects {
// 在这个段落中你可以声明对于所有项目(含根项目)都适用的配置,比如依赖性的仓储等
}
subprojects {
// * 在这个段落中你可以声明适用于各子项目的配置(不包括根项目哦)
version = "0.0.1"
}
// * 对于子项目的特殊配置
project(‘:common‘) {
}
project(‘:api‘) {
}
project(‘:report‘) {
}
project(‘:common‘) {
dependencies {
compile("org.springframework.boot:spring-boot-starter-data-rest")
compile("org.springframework.boot:spring-boot-starter-data-mongodb")
compile("org.projectlombok:lombok:${lombokVersion}")
}
}
project(‘:api‘) {
dependencies {
compile project(‘:common‘)
compile("org.springframework.boot:spring-boot-devtools")
}
}
project(‘:report‘) {
dependencies {
compile project(‘:common‘)
compile("org.springframework.boot:spring-boot-devtools")
compile files(["lib/simsun.jar"])
compile("org.springframework.boot:spring-boot-starter-web")
}
}
apply plugin: "maven"
然后就能和mvn install 一样的执行 gradle install 了特别注意使用gpg, 如果按这下面的一堆文档跟着做的话你要保证你的gpg小于等于2.0版本, 不然就卡在这里了
build.gradle
apply plugin: ‘docker‘
buildscript {
ext {
springBootVersion = ‘2.0.1.RELEASE‘
}
repositories {
mavenCentral()
}
dependencies {
classpath("org.springframework.boot:spring-boot-gradle-plugin:${springBootVersion}")
classpath(‘se.transmode.gradle:gradle-docker:1.2‘)
}
}
task buildDocker(type: Docker, dependsOn: build) {
//设置自动上传的话,命名就不能乱取了,仓库名/镜像名:tag
// push = true
test.enabled=false
applicationName = jar.baseName
dockerfile = file(‘src/main/docker/Dockerfile‘)
doFirst {
copy {
from war
into stageDir
}
}
}
Dockerfile
FROM frolvlad/alpine-oraclejdk8:slim
VOLUME /tmp
# 配置通配符是为了不受版本影响
ADD weixin*.war app.war
# ENTRYPOINT ["java","-Djava.security.egd=file:/dev/./urandom","-jar","/app.war"]
ENTRYPOINT ["java","-jar","/app.war"]
gradle buildDocker
即可构建镜像docker run --name web --link postgre:db -p 5678:8889 -it 镜像
注意其中要关联PostgreSQL的容器标签:ogr 本地库 file dev overflow 缺点 参考 trace 子项目
原文地址:https://www.cnblogs.com/kuangcp/p/9420621.html