Distributions
Distributions define artifacts that may be published using supported packages and announced with supported announcers.
Each distribution is responsible for defining a unique name and a list of artifacts that belong to it.
A distribution requires at least 1 artifact to be listed.
Distributions inherit the configuration specified in the Packagers block and may override it.
Distributions have a type that enables or disables additional features. These types are:
Configuration
Legend:
-
required
-
optional
-
may use environment variable
-
accepts Name Templates
#
distributions:
# A named distribution
#
app:
# Enables or disables the distribution.
# Supported values are [`NEVER`, `ALWAYS`, `RELEASE`, `SNAPSHOT`].
# Defaults to `ALWAYS`.
#
active: ALWAYS
# The distribution type.
# Used to determine packager templates.
# Supported values are: [`JAVA_BINARY`, `SINGLE_JAR`, `JLINK`, `BINARY`, `FLAT-BINARY`, `NATIVE_PACKAGE`].
#
type: JAVA_BINARY
# The stereotype of this distribution.
# Supported values are [`NONE`, `CLI`, `DESKTOP`, `WEB`, `MOBILE`].
# Defaults to `#{project.stereotype}`.
#
stereotype: CLI
#
executable:
# Name of the executable launcher.
# If left undefined, will use `#{distribution.name}`.
#
name: app
# Executable extension on Linux/MacOS.
# If left undefined, value will be left empty.
#
unixExtension: sh
# Executable extension on Windows.
# If left undefined, will use `bat`.
#
windowsExtension: cmd
# A list of tags.
#
tags:
- cli
- awesome
# Additional properties used when evaluating templates.
#
extraProperties:
# Key will be capitalized and prefixed with `distribution`, i.e, `distributionFoo`.
foo: bar
platform:
# Key value pairs.
# Keys match a full platform or an os.name, os.arch.
# Same rules apply as in Platform.
#
replacements:
osx-x86_64: mac
aarch_64: aarch64
x86_64: amd64
linux_musl: alpine
# Includes the default matrix.
#
applyDefaultMatrix: false
# Configures matrix variables.
#
matrix:
vars:
os: [ linux, osx, windows ]
arch: [ arm64, amd64 ]
rows:
- { os: linux, arch: arm64 }
- { os: linux, arch: amd64 }
- { os: osx, arch: arm64 }
- { os: osx, arch: amd64 }
- { os: windows, arch: arm64 }
- { os: windows, arch: amd64 }
# Define a pattern for parameterizable artifacts
#
artifactPattern:
path: path/to/archive
# A list of artifacts.
# At least on entry must be present.
#
artifacts:
- path: path/to/{{distributionName}}-{{projectVersion}}.zip
- path: path/to/{{distributionName}}-{{projectVersion}}-mac.zip
platform: osx
- path: path/to/{{distributionName}}-{{projectVersion}}-win.zip
platform: windows
#
java:
# Maven coordinates: groupId.
# If left undefined, will use `#{project.java.groupId}`.
#
groupId: com.acme
# Maven coordinates: artifactId.
# If left undefined, will use `#{project.java.artifactId}`.
#
artifactId: app
# The minimum Java version required by consumers to run the application.
# If left undefined, will use `#{project.java.version}`.
#
version: 8
# The application's entry point.
# If left undefined, will use `#{project.java.mainClass}`.
#
mainClass: com.acme.Main
# Identifies the project as being member of a multi-project build.
# If left undefined, will use `#{project.java.multiProject}`.
#
multiProject: false
# Additional properties used when evaluating templates.
#
extraProperties:
# Key will be capitalized and prefixed with `java`, i.e, `javaFoo`.
foo: bar
# A named distribution
#
[distributions.app]
# Enables or disables the distribution.
# Supported values are [`NEVER`, `ALWAYS`, `RELEASE`, `SNAPSHOT`].
# Defaults to `ALWAYS`.
#
active = "ALWAYS"
# The distribution type.
# Used to determine packager templates.
# Supported values are: [`JAVA_BINARY`, `SINGLE_JAR`, `JLINK`, `BINARY`, `FLAT-BINARY`, `NATIVE_PACKAGE`].
#
type = "JAVA_BINARY"
# The stereotype of this distribution.
# Supported values are [`NONE`, `CLI`, `DESKTOP`, `WEB`, `MOBILE`].
# Defaults to `#{project.stereotype}`.
#
stereotype = "CLI"
#
[distributions.app.executable]
# Name of the executable launcher.
# If left undefined, will use `#{distribution.name}`.
#
name = "app"
# Executable extension on Linux/MacOS.
# If left undefined, value will be left empty.
#
unixExtension = "sh"
# Executable extension on Windows.
# If left undefined, will use `bat`.
#
windowsExtension = "cmd"
# A list of tags.
#
tags = ["cli", "awesome"]
# Additional properties used when evaluating templates.
#
extraProperties.foo = "bar"
# Key will be capitalized and prefixed with `distribution`, i.e, `distributionFoo`.
# Key value pairs.
# Keys match a full platform or an os.name, os.arch.
# Same rules apply as in Platform.
#
[distributions.app.platform.replacements]
osx-x86_64 = "mac"
aarch_64 = "aarch64"
x86_64 = "amd64"
linux_musl = "alpine"
# Includes the default matrix.
#
applyDefaultMatrix = false
# Configures matrix variables.
#
matrix.vars.os = [ "linux", "osx", "windows" ]
matrix.vars.arch= [ "arm64", "amd64" ]
rows = [{ os = "linux", arch = "arm64" },
{ os = "linux", arch = "amd64" },
{ os = "osx", arch = "arm64" },
{ os = "osx", arch = "amd64" },
{ os = "windows", arch = "arm64" },
{ os = "windows", arch = "amd64" }]
# Define a pattern for parameterizable artifacts
#
artifactPattern.path = "path/to/archive"
# A list of artifacts.
# At least on entry must be present.
#
artifacts = [
{ path = "path/to/{{distributionName}}-{{projectVersion}}.zip" },
{ path = "path/to/{{distributionName}}-{{projectVersion}}-mac.zip", platform = "osx" },
{ path = "path/to/{{distributionName}}-{{projectVersion}}-win.zip", platform = "windows" }
]
# Maven coordinates: groupId.
# If left undefined, will use `#{project.java.groupId}`.
#
java.groupId = "com.acme"
# Maven coordinates: artifactId.
# If left undefined, will use `#{project.java.artifactId}`.
#
java.artifactId = "app"
# The minimum Java version required by consumers to run the application.
# If left undefined, will use `#{project.java.version}`.
#
java.version = "8"
# The application's entry point.
# If left undefined, will use `#{project.java.mainClass}`.
#
java.mainClass = "com.acme.Main"
# Identifies the project as being member of a multi-project build.
# If left undefined, will use `#{project.java.multiProject}`.
#
java.multiProject = false
# Additional properties used when evaluating templates.
#
java.extraProperties.foo = "bar"
# Key will be capitalized and prefixed with `java`, i.e, `javaFoo`.
{
//
"distributions": {
// A named distribution
//
"app": {
// Enables or disables the distribution.
// Supported values are [`NEVER`, `ALWAYS`, `RELEASE`, `SNAPSHOT`].
// Defaults to `ALWAYS`.
//
"active": "ALWAYS",
// The distribution type.
// Used to determine packager templates.
// Supported values are: [`JAVA_BINARY`, `SINGLE_JAR`, `JLINK`, `BINARY`, `FLAT-BINARY`, `NATIVE_PACKAGE`].
//
"type": "JAVA_BINARY",
// The stereotype of this distribution.
// Supported values are [`NONE`, `CLI`, `DESKTOP`, `WEB`, `MOBILE`].
// Defaults to `#{project.stereotype}`.
//
"stereotype": "CLI",
//
"executable": {
// Name of the executable launcher.
// If left undefined, will use `#{distribution.name}`.
//
"name": "app",
// Executable extension on Linux/MacOS.
// If left undefined, value will be left empty.
//
"unixExtension": "sh",
// Executable extension on Windows.
// If left undefined, will use `bat`.
//
"windowsExtension": "cmd"
},
// A list of tags.
//
"tags": [
"cli",
"awesome"
],
// Additional properties used when evaluating templates.
//
"extraProperties": {
// Key will be capitalized and prefixed with `distribution`, i.e, `distributionFoo`.
"foo": "bar"
},
"platform": {
// Key value pairs.
// Keys match a full platform or an os.name, os.arch.
// Same rules apply as in Platform.
//
"replacements": {
"osx-x86_64": "mac",
"aarch_64": "aarch64",
"x86_64": "amd64",
"linux_musl": "alpine"
}
},
// Includes the default matrix.
//
"applyDefaultMatrix": false,
// Configures matrix variables.
//
"matrix": {
"vars": {
"os": [ "linux", "osx", "windows" ],
"arch": [ "arm64", "amd64" ]
},
"rows": [
{ "os": "linux", "arch": "arm64" },
{ "os": "linux", "arch": "amd64" },
{ "os": "osx", "arch": "arm64" },
{ "os": "osx", "arch": "amd64" },
{ "os": "windows", "arch": "arm64" },
{ "os": "windows", "arch": "amd64" }
]
},
// Define a pattern for parameterizable artifacts
//
"artifactPattern": {
"path": "path/to/archive"
},
// A list of artifacts.
// At least on entry must be present.
//
"artifacts": [
{
"path": "path/to/{{distributionName}}-{{projectVersion}}.zip"
},
{
"path": "path/to/{{distributionName}}-{{projectVersion}}-mac.zip",
"platform": "osx"
},
{
"path": "path/to/{{distributionName}}-{{projectVersion}}-win.zip",
"platform": "windows"
}
],
//
"java": {
// Maven coordinates: groupId.
// If left undefined, will use `#{project.java.groupId}`.
//
"groupId": "com.acme",
// Maven coordinates: artifactId.
// If left undefined, will use `#{project.java.artifactId}`.
//
"artifactId": "app",
// The minimum Java version required by consumers to run the application.
// If left undefined, will use `#{project.java.version}`.
//
"version": "8",
// The application's entry point.
// If left undefined, will use `#{project.java.mainClass}`.
//
"mainClass": "com.acme.Main",
// Identifies the project as being member of a multi-project build.
// If left undefined, will use `#{project.java.multiProject}`.
//
"multiProject": false,
// Additional properties used when evaluating templates.
//
"extraProperties": {
// Key will be capitalized and prefixed with `java`, i.e, `javaFoo`.
"foo": "bar"
}
}
}
}
}
<jreleaser>
<!--
-->
<distributions>
<!--
A named distribution
-->
<app>
<!--
Enables or disables the distribution.
Supported values are [`NEVER`, `ALWAYS`, `RELEASE`, `SNAPSHOT`].
Defaults to `ALWAYS`.
-->
<active>ALWAYS</active>
<!--
The distribution type.
Used to determine packager templates.
Supported values are>[`JAVA_BINARY`, `SINGLE_JAR`, `JLINK`, `BINARY`, `FLAT-BINARY`, `NATIVE_PACKAGE`].
-->
<type>JAVA_BINARY</type>
<!--
The stereotype of this distribution.
Supported values are [`NONE`, `CLI`, `DESKTOP`, `WEB`, `MOBILE`].
Defaults to `#{project.stereotype}`.
-->
<stereotype>CLI</stereotype>
<!--
-->
<executable>
<!--
Name of the executable launcher.
If left undefined, will use `#{distribution.name}`.
-->
<name>app</name>
<!--
Executable extension on Linux/MacOS.
If left undefined, value will be left empty.
-->
<unixExtension>sh</unixExtension>
<!--
Executable extension on Windows.
If left undefined, will use `bat`.
-->
<windowsExtension>cmd</windowsExtension>
</executable>
<!--
A list of tags.
-->
<tags>
<tag>cli</tag>
<tag>awesome</tag>
</tags>
<!--
Additional properties used when evaluating templates.
-->
<extraProperties>
<!--
Key will be capitalized and prefixed with `distribution`, i.e, `distributionFoo`.
-->
<foo>bar</foo>
</extraProperties>
<!--
-->
<platform>
<!--
Key value pairs.
Keys match a full platform or an os.name, os.arch.
Same rules apply as in Platform.
-->
<replacements>
<osx-x86_64>mac</osx-x86_64>
<aarch_64>aarch64</aarch_64>
<x86_64>amd64</x86_64>
<linux_musl>alpine</linux_musl>
</replacements>
</platform>
<!--
Includes the default matrix.
-->
<applyDefaultMatrix>false</applyDefaultMatrix>
<!--
Configures matrix variables.
-->
<matrix>
<vars>
<os>
<e>linux</e>
<e>osx</e>
<e>windows</e>
</os>
<arch>
<e>arm64</e>
<e>amd64</e>
</arch>
</vars>
<rows>
<row>
<os>linux</os>
<arch>arm64</arch>
</row>
<row>
<os>linux</os>
<arch>amd64</arch>
</row>
<row>
<os>osx</os>
<arch>arm64</arch>
</row>
<row>
<os>osx</os>
<arch>amd64</arch>
</row>
<row>
<os>windows</os>
<arch>arm64</arch>
</row>
<row>
<os>windows</os>
<arch>amd64</arch>
</row>
</rows>
</matrix>
<!--
Define a pattern for parameterizable artifacts
-->
<artifactPattern>
<path>path/to/archive</path>
</artifactPattern>
<!--
A list of artifacts.
At least on entry must be present.
-->
<artifacts>
<artifact>
<path>path/to/{{distributionName}}-{{projectVersion}}.zip</path>
</artifact>
<artifact>
<path>path/to/{{distributionName}}-{{projectVersion}}-mac.zip</path>
<platform>osx</platform>
</artifact>
<artifact>
<path>path/to/{{distributionName}}-{{projectVersion}}-win.zip</path>
<platform>windows</platform>
</artifact>
</artifacts>
<!--
-->
<java>
<!--
Maven coordinates>groupId.
If left undefined, will use `#{project.java.groupId}`.
-->
<groupId>com.acme</groupId>
<!--
Maven coordinates>artifactId.
If left undefined, will use `#{project.java.artifactId}`.
-->
<artifactId>app</artifactId>
<!--
The minimum Java version required by consumers to run the application.
If left undefined, will use `#{project.java.version}`.
-->
<version>8</version>
<!--
The application's entry point.
If left undefined, will use `#{project.java.mainClass}`.
-->
<mainClass>com.acme.Main</mainClass>
<!--
Identifies the project as being member of a multi-project build.
If left undefined, will use `#{project.java.multiProject}`.
-->
<multiProject>false</multiProject>
<!--
Additional properties used when evaluating templates.
-->
<extraProperties>
<!--
Key will be capitalized and prefixed with `java`, i.e, `javaFoo`.
-->
<foo>bar</foo>
</extraProperties>
</java>
</app>
</distributions>
</jreleaser>
jreleaser {
//
distributions {
// A named distribution
//
app {
// Enables or disables the distribution.
// Supported values are [`NEVER`, `ALWAYS`, `RELEASE`, `SNAPSHOT`].
// Defaults to `ALWAYS`.
//
active = 'ALWAYS'
// The distribution type.
// Used to determine packager templates.
// Supported values are = [`JAVA_BINARY`, `SINGLE_JAR`, `JLINK`, `BINARY`, `FLAT-BINARY`, `NATIVE_PACKAGE`].
//
distributionType = 'JAVA_BINARY'
// The stereotype of this distribution.
// Supported values are [`NONE`, `CLI`, `DESKTOP`, `WEB`, `MOBILE`].
// Defaults to `#{project.stereotype}`.
//
stereotype = 'CLI'
//
executable {
// Name of the executable launcher.
// If left undefined, will use `#{distribution.name}`.
//
name = 'app'
// Executable extension on Linux/MacOS.
// If left undefined, value will be left empty.
//
unixExtension = 'sh'
// Executable extension on Windows.
// If left undefined, will use `bat`.
//
windowsExtension = 'cmd'
}
// A list of tags.
//
tags = ['cli', 'awesome']
// Additional properties used when evaluating templates.
// Key will be capitalized and prefixed with `distribution`, i.e, `distributionFoo`.
//
extraProperties.put('foo', 'bar')
//
platform {
// Key value pairs.
// Keys match a full platform or an os.name, os.arch.
// Same rules apply as in Platform.
//
replacements = [
'osx-x86_64': 'mac',
aarch_64: 'aarch64',
x86_64: 'amd64',
linux_musl: 'alpine'
]
}
// Includes the default matrix.
//
applyDefaultMatrix = false
// Configures matrix variables.
//
matrix {
variable('os', ['linux', 'osx', 'windows'])
variable('arch', ['arm64', 'amd64'])
row(os: 'linux', arch: 'arm64')
row(os: 'linux', arch: 'amd64')
row(os: 'osx', arch: 'arm64')
row(os: 'osx', arch: 'amd64')
row(os: 'windows', arch: 'arm64')
row(os: 'windows', arch: 'amd64')
}
// Define a pattern for parameterizable artifacts
//
artifactPattern {
path = 'path/to/jdk'
}
// A list of artifacts.
// At least on entry must be present.
//
artifact {
path = "path/to/{{distributionName}}-{{projectVersion}}.zip"
}
artifact {
path = "path/to/{{distributionName}}-{{projectVersion}}-mac.zip"
platform = 'osx'
}
artifact {
path = "path/to/{{distributionName}}-{{projectVersion}}-win.zip"
platform = 'windows'
}
//
java {
// Maven coordinates = groupId.
// If left undefined, will use `#{project.java.groupId}`.
//
groupId = 'com.acme'
// Maven coordinates = artifactId.
// If left undefined, will use `#{project.java.artifactId}`.
//
artifactId = 'app'
// The minimum Java version required by consumers to run the application.
// If left undefined, will use `#{project.java.version}`.
//
version = '8'
// The application's entry point.
// If left undefined, will use `#{project.java.mainClass}`.
//
mainClass = 'com.acme.Main'
// Identifies the project as being member of a multi-project build.
// If left undefined, will use `#{project.java.multiProject}`.
//
multiProject = false
// Additional properties used when evaluating templates.
// Key will be capitalized and prefixed with `java`, i.e, `javaFoo`.
//
extraProperties.put('foo', 'bar')
}
}
}
}
It’s recommended to list universal artifacts first, then platform specific.
The value of platform
is dictated by the normalized values detected by
os-maven-plugin. You may use the plain platform
value or append a
arch
classifier. The following values are currently recognized:
- platform
-
aix
,hpux
,os400
,linux
,linux_musl
,osx
,freebsd
,openbsd
,netbsd
,sunos
,windows
,zos
. - arch
-
x86_64
,x86_32
,itanium_64
,itanium_32
,sparc_32
,sparc_64
,arm_32
,aarch_64
,mips_32
,mipsel_32
,mips_64
,mipsel_64
,ppc_32
,ppcle_32
,ppc_64
,ppcle_64
,s390_32
,s390_64
,riscv
Examples:
-
osx
-
osx-aarch_64
-
windows
-
linux
-
linux-x86_64
Use linux_musl for artifacts that target Alpine Linux.
|
Platform detection may be overridden by defining an environment variable or a System property named
JRELEASER_PLATFORM_OVERRIDE
.
Environment
When not explicitly set, the value of the following properties may be resolved from an environment variable or a system property as shown in the table. The system property takes precedence over the environment variable.
System Property | Environment Variable |
---|---|
active |
|
jreleaser.distributions.${name}.active |
JRELEASER_DISTRIBUTIONS_${name}_ACTIVE |
Substitute ${name} for the value of the named instance. |
Space (' '), underscore (_
), and dash (-
) will be replaced by dot (.
) to separate tokens in the System property.
Space (' '), dash (-
), and dot (.
) will be replaced by underscore (_
) to separate tokens in the environment variable,
such that:
${name} | System Property | Environment Variable |
---|---|---|
foobar |
|
|
fooBar |
|
|
foo bar |
|
|
foo-bar |
|
|
foo_bar |
|
|
foo.bar |
|
|
Matrix
Parameterize artifact resolution with a set of key/value pairs. For example the following definitions are equivalent
matrix:
rows:
- { platform: osx-aarch_64 }
- { platform: osx-x86_64 }
- { platform: linux-x86_64 }
distributions:
helloworld:
executable:
windowsExtension: exe
applyDefaultMatrix: true
artifactPattern:
path: '{{artifactsDir}}/{{distributionName}}-{{projectVersion}}-{{matrix.platform}}.zip'
distributions:
helloworld:
executable:
windowsExtension: exe
artifacts:
- path: '{{artifactsDir}}/{{distributionName}}-{{projectVersion}}-osx-aarch_64.zip'
platform: 'osx-aarch_64'
- path: '{{artifactsDir}}/{{distributionName}}-{{projectVersion}}-osx-x86_64.zip'
platform: 'osx-x86_64'
- path: '{{artifactsDir}}/{{distributionName}}-{{projectVersion}}-linux-x86_64.zip'
platform: 'linux-x86_64'