首页
/ Gradle Cargo 插件技术文档

Gradle Cargo 插件技术文档

2024-12-24 08:17:46作者:魏侃纯Zoe

1. 安装指南

1.1 添加插件到构建脚本

要使用 Gradle Cargo 插件,首先需要将其二进制文件添加到构建脚本的类路径中。插件可以在 Gradle 插件门户中找到。以下代码片段展示了如何使用 buildscript 语法来获取插件:

buildscript {
    repositories {
        gradlePluginPortal()
    }

    dependencies {
        classpath 'com.bmuschko:gradle-cargo-plugin:2.9.0'
    }
}

1.2 应用插件

插件 JAR 文件包含两个插件:

  • com.bmuschko.cargo-base:提供 Cargo 自定义任务类型、预配置类路径和部署项。
  • com.bmuschko.cargo:提供一组本地和远程 Cargo 任务,并公开扩展以进行配置。

大多数用户会选择使用 com.bmuschko.cargo 插件,因为它可以快速上手。以下是应用该插件的代码示例:

apply plugin: 'com.bmuschko.cargo'

如果你需要完全控制部署任务,可以使用 com.bmuschko.cargo-base 插件。以下是应用该插件的代码示例:

apply plugin: 'com.bmuschko.cargo-base'

1.3 配置 Cargo 版本

com.bmuschko.cargo-base 插件已经为 Cargo 设置了依赖项,并选择了一个默认版本的库。你也可以定义自定义版本的 Cargo 库。以下示例展示了如何使用 Cargo 1.9.10 版本:

dependencies {
    def cargoVersion = '1.9.10'
    cargo "org.codehaus.cargo:cargo-core-uberjar:$cargoVersion",
          "org.codehaus.cargo:cargo-licensed-dtds:$cargoVersion",
          "org.codehaus.cargo:cargo-ant:$cargoVersion"
}

2. 项目使用说明

2.1 插件功能

Gradle Cargo 插件通过利用 Cargo Ant 任务,为任何给定的 Gradle 构建提供了将 Web 应用程序部署到本地和远程容器的能力。该插件支持 WAR 和 EAR 工件。

2.2 典型用例

该插件的典型用例是支持开发过程中的部署。需要注意的是,Cargo 使用热部署,随着时间的推移,这会填满运行容器的 JVM 进程的 PermGen 内存,最终导致 java.lang.OutOfMemoryError

2.3 容器管理

Cargo 支持通过 Cargo daemon 进行容器管理(启动/停止远程容器)。然而,在持续部署场景中,通常需要执行更复杂的操作。

3. 项目 API 使用文档

3.1 预定义任务

cargo 插件预定义了以下任务:

任务名称 依赖任务 类型 描述
cargoDeployRemote - CargoDeployRemote 将可部署项部署到远程容器。
cargoUndeployRemote - CargoUndeployRemote 从远程容器中取消部署可部署项。
cargoRedeployRemote - CargoRedeployRemote 重新部署可部署项到远程容器。
cargoRunLocal - CargoRunLocal 启动本地容器,部署可部署项并等待停止。
cargoStartLocal - CargoStartLocal 启动本地容器,部署可部署项并执行任务。
cargoRedeployLocal - CargoRedeployLocal 在本地容器上重新部署可部署项。
cargoStopLocal - CargoStopLocal 停止本地容器。
cargoConfigureLocal - CargoConfigureLocal 配置本地容器。

3.2 扩展属性

cargo 插件定义了以下约定属性:

  • containerId:目标容器的 ID。
  • port:容器响应的 TCP 端口(默认为 8080)。

你可以在 cargo 闭包中定义 1..n 个部署工件的可选属性,每个部署工件在其自己的闭包中指定:

  • file:可以传递给 Project.files(Object...) 的任何类型,并解析为单个文件或目录。
  • context:容器处理 Web 应用程序的 URL 上下文(默认为 WAR/EAR 名称)。

4. 项目安装方式

4.1 本地安装

要安装本地容器,可以使用 cargoRunLocalcargoStartLocal 任务。以下是一个示例:

cargo {
    containerId = 'tomcat9x'
    port = 8080

    local {
        jvmArgs = '-Xmx512m'
        outputFile = file('build/output.log')
        logFile = file('build/cargo.log')
        logLevel = 'high'
    }
}

4.2 远程安装

要安装远程容器,可以使用 cargoDeployRemote 任务。以下是一个示例:

cargo {
    containerId = 'tomcat9x'
    port = 8080

    remote {
        protocol = 'http'
        hostname = 'remote-server'
        username = 'admin'
        password = 'password'
    }
}

通过以上步骤,你可以成功安装并使用 Gradle Cargo 插件进行本地和远程容器的部署。

登录后查看全文
热门项目推荐

项目优选

收起
docsdocs
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
143
1.91 K
kernelkernel
deepin linux kernel
C
22
6
nop-entropynop-entropy
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
8
0
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
192
273
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
927
551
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
421
392
openGauss-serveropenGauss-server
openGauss kernel ~ openGauss is an open source relational database management system
C++
145
189
金融AI编程实战金融AI编程实战
为非计算机科班出身 (例如财经类高校金融学院) 同学量身定制,新手友好,让学生以亲身实践开源开发的方式,学会使用计算机自动化自己的科研/创新工作。案例以量化投资为主线,涉及 Bash、Python、SQL、BI、AI 等全技术栈,培养面向未来的数智化人才 (如数据工程师、数据分析师、数据科学家、数据决策者、量化投资人)。
Jupyter Notebook
75
64
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
344
1.3 K
easy-eseasy-es
Elasticsearch 国内Top1 elasticsearch搜索引擎框架es ORM框架,索引全自动智能托管,如丝般顺滑,与Mybatis-plus一致的API,屏蔽语言差异,开发者只需要会MySQL语法即可完成对Es的相关操作,零额外学习成本.底层采用RestHighLevelClient,兼具低码,易用,易拓展等特性,支持es独有的高亮,权重,分词,Geo,嵌套,父子类型等功能...
Java
36
8