Gradle - 部署
Gradle 提供了多种方式来部署构建产物仓库。在将工件的签名部署到 Maven 仓库时,您还需要对发布的 POM 文件进行签名。
Maven-publish 插件
默认情况下,Gradle 提供了 maven-publish 插件。它用于发布 Gradle 脚本。请查看以下代码。
apply plugin: 'java'
apply plugin: 'maven-publish'
publishing {
publications {
mavenJava(MavenPublication) {
from components.java
}
}
repositories {
maven {
url "$buildDir/repo"
}
}
}
当应用了 Java 和 maven-publish 插件时,有多种发布选项。请查看以下代码,它将项目部署到远程仓库。
apply plugin: 'groovy'
apply plugin: 'maven-publish'
group 'workshop'
version = '1.0.0'
publishing {
publications {
mavenJava(MavenPublication) {
from components.java
}
}
repositories {
maven {
default credentials for a nexus repository manager
credentials {
username 'admin'
password 'admin123'
}
// url to the releases maven repository
url "http://localhost:8081/nexus/content/repositories/releases/"
}
}
}
从 Maven 转换为 Gradle
有一个特殊的命令用于将 Apache Maven 的 pom.xml 文件转换为 Gradle 构建文件,前提是所有使用的 Maven 插件都已知晓此任务。
在本节中,以下 pom.xml Maven 配置将被转换为 Gradle 项目。
<project xmlns = "http://maven.apache.org/POM/4.0.0"
xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation = "http://maven.apache.org/POM/4.0.0
http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.example.app</groupId>
<artifactId>example-app</artifactId>
<packaging>jar</packaging>
<version>1.0.0-SNAPSHOT</version>
<dependencies>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.11</version>
<scope>test</scope>
</dependency>
</dependencies>
</project>
您可以在命令行中使用以下命令,这将生成以下 Gradle 配置。
C:\> gradle init --type pom
init 任务依赖于 wrapper 任务,因此会创建一个 Gradle wrapper。
生成的 build.gradle 文件类似于以下内容 −
apply plugin: 'java'
apply plugin: 'maven'
group = 'com.example.app'
version = '1.0.0-SNAPSHOT'
description = """"""
sourceCompatibility = 1.5
targetCompatibility = 1.5
repositories {
maven { url "http://repo.maven.apache.org/maven2" }
}
dependencies {
testCompile group: 'junit', name: 'junit', version:'4.11'
}