原先在公司做项目时,写了一个简单的基于gradle部署项目的脚本,今天翻出来记录一下 

一、build.gradle

buildscript {
ext {
env = System.getProperty("env") ?: "test"
jvmArgs = "-server -Xms128m -Xmx128m -XX:NewRatio=4 -XX:SurvivorRatio=16 -XX:MaxTenuringThreshold=15 -XX:CMSInitiatingOccupancyFraction=80 -XX:+UseConcMarkSweepGC -XX:+CMSClassUnloadingEnabled -XX:+ExplicitGCInvokesConcurrent -XX:+DoEscapeAnalysis -XX:-HeapDumpOnOutOfMemoryError"
if (env == "prod") {
jvmArgs = "-server -Xms2g -Xmx2g -XX:NewRatio=4 -XX:SurvivorRatio=16 -XX:MaxTenuringThreshold=15 -XX:CMSInitiatingOccupancyFraction=80 -XX:+UseConcMarkSweepGC -XX:+CMSClassUnloadingEnabled -XX:+ExplicitGCInvokesConcurrent -XX:+DoEscapeAnalysis -XX:-HeapDumpOnOutOfMemoryError"
}
userHome = System.getProperty("user.home")
osName = System.getProperty("os.name")
} repositories {
jcenter()
}
dependencies {
classpath 'org.hidetake:gradle-ssh-plugin:2.7.0'
classpath 'co.tomlee.gradle.plugins:gradle-thrift-plugin:0.0.6'
}
} allprojects {
apply plugin: 'idea'
apply plugin: 'eclipse'
apply plugin: 'org.hidetake.ssh'
group = 'com.mwee.information.core'
version = '1.0-SNAPSHOT'
ssh.settings {
timeoutSec = 60
knownHosts = allowAnyHosts
}
defaultTasks 'clean', 'copyPartDependencies' //排除Log4j依赖
configurations {
compile.exclude module: 'slf4j-log4j12'
compile.exclude module: 'org.apache.logging.log4j'
compile.exclude module: 'log4j'
all*.exclude group: 'org.apache.logging.log4j'
all*.exclude group: 'log4j'
} } subprojects {
apply plugin: 'java'
sourceCompatibility = 1.8
targetCompatibility = 1.8
repositories {
mavenLocal()
maven { url "http://114.80.88.52:9001/nexus/content/groups/public/" }
}
sourceSets {
main {
java {
srcDirs = ['src/main/java']
}
resources {
srcDirs = ["src/main/resources", "src/main/profile/$env"]
}
}
}
dependencies {
compile("org.codehaus.groovy:groovy-all:2.2.1")
compile 'org.codehaus.groovy:groovy-backports-compat23:2.4.5'
compile("org.springframework.boot:spring-boot-starter-web:1.4.2.RELEASE")
compile("org.apache.commons:commons-lang3:3.4")
compile("org.apache.commons:commons-collections4:4.1")
compile "org.apache.commons:commons-pool2:2.4.2"
compile group: 'com.alibaba', name: 'fastjson', version: '1.2.12'
// https://mvnrepository.com/artifact/com.fasterxml.jackson.core/jackson-databind
compile group: 'com.fasterxml.jackson.core', name: 'jackson-databind', version: '2.8.6'
// https://mvnrepository.com/artifact/com.fasterxml.jackson.core/jackson-core
compile group: 'com.fasterxml.jackson.core', name: 'jackson-core', version: '2.8.6'
compile group: 'org.aspectj', name: 'aspectjrt', version: '1.8.7'
compile group: 'org.aspectj', name: 'aspectjweaver', version: '1.8.7'
compile group: 'com.thoughtworks.xstream', name: 'xstream', version: '1.4.1'
compile(group: 'org.mortbay.jetty', name: 'jetty', version: '6.1.26')
compile group: 'org.projectlombok', name: 'lombok', version: '1.16.8'
compile group: 'com.squareup.okhttp', name: 'okhttp', version: '2.7.5'
compile group: 'com.google.guava', name: 'guava', version: '18.0'
compile group: 'commons-lang', name: 'commons-lang', version: '2.6'
compile group: 'com.jcraft', name: 'jsch', version: '0.1.53'
testCompile group: 'junit', name: 'junit', version: '4.12'
testCompile "org.springframework:spring-test:4.3.4.RELEASE"
compile "javax.validation:validation-api:1.1.0.Final"
compile "org.hibernate:hibernate-validator:5.2.4.Final"
}
//gradle utf-8 compile
tasks.withType(JavaCompile) {
options.encoding = 'UTF-8'
} task copyAllDependencies(type: Copy, dependsOn: jar) {
description = "拷贝全部依赖的jar包"
from configurations.runtime
into 'build/libs'
} task copyPartDependencies(type: Copy, dependsOn: jar) {
description = "拷贝部分依赖的jar"
from configurations.runtime
into 'build/libs'
doLast {
file("build/libs").listFiles({ !it.name.endsWith("-SNAPSHOT.jar") } as FileFilter).each {
it.delete()
}
} } }

二、对应模块下的build.gradle

def mainClass = "com.hzgj.information.rest.user.run.UserServiceProvider"
def appHome = "/home/appsvr/apps/rest_user"
def javaCommand = "nohup java $jvmArgs -Djava.ext.dirs=$appHome/libs -Denv=$env $mainClass >$appHome/shell.log 2>&1 &"
def index = System.getProperty("index") def remote = remotes {
test_0 {
role 'test_0'
host = '10.0.21.152'
if (file("$userHome/.ssh/id_rsa").exists()) {
user = 'appsvr'
identity = file("$userHome/.ssh/id_rsa")
} else {
user = 'appsvr'
password = 'xxx'
} } test_1 {
role 'test_1'
host = '10.0.146.20'
if (file("$userHome/.ssh/id_rsa").exists()) {
user = 'appsvr'
identity = file("$userHome/.ssh/id_rsa")
} else {
user = 'appsvr'
password = 'xxx'
}
}
home {
role 'home'
host = '192.168.109.130'
user = 'appsvr'
password = 'xxx'
// identity = file('id_rsa')
} }
task deploy << {
description = "拷贝jar包并启动java服务"
def roles = remote.findAll {
def currentEnv = index == null ? "$env" : "$env" + "_" + index
it['roles'][0].toString().contains(currentEnv)
}
ssh.run {
roles.each {
def role = it['roles'][0].toString()
session(remotes.role(role)) {
try {
execute("ls $appHome")
} catch (Exception e) {
println("#############目录[$appHome]不存在,将自动创建############")
execute("mkdir -p $appHome")
}
finally {
def r = '$1'
def pid = execute("jps -l |grep '$mainClass' |awk \'{print $r}\'")
if (pid) {
execute("kill -9 $pid")
}
put from: 'build/libs', into: "$appHome"
println("###############准备启动java服务[$javaCommand]####################")
execute("$javaCommand")
sleep(10000)
pid = execute("jps -l |grep '$mainClass' |awk \'{print $r}\'")
if (pid) {
println("#####$mainClass [$pid] 启动成功...######")
execute("rm -f $appHome/shell.log")
} else {
println("#$mainClass 启动失败...输出日志如下:#")
execute("cat $appHome/shell.log")
}
}
}
} }
} task stop << {
def roles = remote.findAll {
def currentEnv = index == null ? "$env" : "$env" + "_" + index
it['roles'][0].toString().contains(currentEnv)
}
ssh.run {
roles.each {
session(remotes.role("$env")) {
def r = '$1'
def pid = execute("jps -l |grep '$mainClass' |awk \'{print $r}\'")
if (pid) {
execute("kill -9 $pid")
}
}
}
}
}
task start << {
def roles = remote.findAll {
def currentEnv = index == null ? "$env" : "$env" + "_" + index
it['roles'][0].toString().contains(currentEnv)
}
ssh.run {
roles.each {
def role = it['roles'][0].toString()
session(remotes.role(role)) {
def r = '$1'
def pid = execute("jps -l |grep '$mainClass' |awk \'{print $r}\'")
if (pid) {
execute("kill -9 $pid")
}
println("###############准备启动java服务[$javaCommand]####################")
execute("$javaCommand")
sleep(10000)
pid = execute("jps -l |grep '$main Class' |awk \'{print $r}\'")
if (pid) {
println("#$mainClass [$pid] 启动成功...#")
execute("rm -f $appHome/shell.log")
} else {
println("#$mainClass 启动失败...输出日志如下:#")
execute("cat $appHome/shell.log")
}
}
}
} }

三、使用方式

1.先运行gradle copyAll -x test 进行打包操作,该操作会将该模块所有的依赖的jar

2.进入到对应的模块下 运行gradle deploy -Denv=xxx -Dindex=xxx ,什么意思呢?-Denv代表哪一个环境 -Dindex指定该环境下哪个节点进行发布

3.gradle start -Denv=xxx -Dindex=xxx 运行当前环境下的应用

Gradle学习之部署上传项目的更多相关文章

  1. Git学习-上传项目到github

    现在流行把项目代码上传到git上,今天试了好久,终于成功上传到git了,特做点笔记. 准备工作 在github上注册一个账号,创建一个仓库. 创建好仓库,得到它的地址: 开始上传 一.新建一个文件夹, ...

  2. git上传项目代码到github

    参考: git学习——上传项目代码到github github上传时出现error: src refspec master does not match any解决办法 git 上传本地文件到gith ...

  3. GitHub教程--上传项目四步法 GitBash命令行下使用方法

    之前就用过GitHub,感觉用GitHub托管自己的代码非常不错.可是之前用的都是窗口化的TortoiseGit,省了很多命令行的操作,但是个人非常喜欢使用命令行,于是,今天就试着用了用GitBash ...

  4. Windows下上传项目到github

    首先,一定要有耐心.看到一大堆的命令行(其实并没有一大堆)不要觉得枯燥,最后当你成功把你的项目上传上去之后那种胜利的成果,还是挺有意思的.本人第一次写博客,勿喷. 我写的是主要的流程,详细内容还请移步 ...

  5. 手把手教你用git和SourceTree上传项目到github细解(转)

    尊重原创:https://blog.csdn.net/qq_32365567/article/details/52859166 一.引言 我想大家现在都很熟悉github了,也能运用github上开源 ...

  6. git上传项目到github远程库

    最近在学习使用 git 上传管理项目,依照教程,建好了一个远程库,也实现了本地库与远程库的项目同步上传,但是在试着将本地库里的项目上传到另一个新建远程库时遇到了问题,一直上传不成功,经过一番查找摸索终 ...

  7. 利用Git上传项目到github以及遇到的问题

    今天学习如何利用git从本地端上传项目,以及遇到问题的解决方法 1.要有自己的github账号,并创建一个仓库, 2.输入仓库的名称,直接Create 注:记住常见成功后的这个地址,后边要用到: 3. ...

  8. Git安装配置及第一次上传项目到GitHub

    平时的学习工作少不了保存自己的Code到代码库,这里必须要使用到Git与GitHub. 1.   关于Git的安装 下载Git:下载地址:https://git-scm.com/downloads  ...

  9. ubuntu在github上传项目

    GitHub是一个面向开源及私有软件项目的托管平台,因为只支持git 作为唯一的版本库格式进行托管,故名GitHub. 作为开源代码库以及版本控制系统,Github拥有超过900万开发者用户.随着越来 ...

随机推荐

  1. 超绚丽CSS3多色彩发光立方体旋转动画

    CSS3添加了几个动画效果的属性,通过设置这些属性,可以做出一些简单的动画效果而不需要再去借助JavaScript.css3动画的属性主要分为三类:transform.transition以及anim ...

  2. python之路--day11---迭代器和生成器

    迭代: 迭代是一个重复的过程,每次重复即一次迭代,并且每次迭代的结果都是下一次迭代的初始值 为什么要有迭代器: 数据类型的取值,字符串,列表,元组依靠索引可以取值,但是字典,集合,文件这些数据类型无法 ...

  3. 新概念英语(1-123)A trip to Australia

    Who is the man with the beard?(胡须)A:Look, Scott. This is a photograph I took during my trip to Austr ...

  4. 新概念英语(1-41)Penny's bag

    新概念英语(1-41)Penny's bag Who is the tin of tobacco for? A:Is that bag heavy, Penny? B:Not very. A:Here ...

  5. 新概念英语(1-29)Come in, Amy.

    How must Amy clean the floor? A:Come in, Amy. Shut the door, please. This bedroom's very untidy. B:W ...

  6. 【原生js实现一键回到顶部】

    <!DOCTYPE html><html> <head> <meta charset="UTF-8"> <title>& ...

  7. 前端之HTML内容

    一.HTML介绍 1.Web服务本质 当我们在浏览器中输入一个url后打开一个页面这个过程实质是一个网络编程中的sockt服务端接受指令并发送指令的一个过程.本质顺序是: 浏览器发请求——>HT ...

  8. Python入门之函数的形式参数与实参/参数的具体使用方法

    本篇目录: 一. 函数参数之形式参数与实参 二. 函数参数的具体使用 #1.位置参数:按照从左到右的顺序定义的参数 位置形参:必选参数 位置实参:按照位置给形参传值 #2.关键字参数:按照key=va ...

  9. Tumblr:我们是如何从 PHP 5 升级到 PHP 7 的

    Tumblr 团队经常在寻找新的方式来提升网站的性能.这意味着要给访问量大的代码增加缓存,找到更快的 CDN 配置,或者升级基础软件. 最近,通过一次跨团队的努力,我们将全部 web 服务器战舰从 P ...

  10. ArUco----一个微型现实增强库的介绍及视觉应用(二)

    ArUco----一个微型现实增强库的介绍及视觉应用(二) 一.第一个ArUco的视觉应用 首先介绍第一个视觉应用的Demo,这个应用场景比较简单,下面具体介绍: 1. 应用场景 主线程:通过摄像头检 ...