Skip to content

Commit

Permalink
WIP: Use 'buildx' to build multiarch JIT image
Browse files Browse the repository at this point in the history
* Add Gradle task to build multiplatform (AMD64+ARM64) docker image
  for the `-jit` version.
* This image should push to our Docker registry as version 0.3.17

TODO:

1. Implement this for the Graal native-image container build
  • Loading branch information
msgilligan committed Jun 7, 2023
1 parent f377c4c commit 75447c8
Show file tree
Hide file tree
Showing 3 changed files with 18 additions and 4 deletions.
2 changes: 1 addition & 1 deletion .github/workflows/gradle.yml
Original file line number Diff line number Diff line change
Expand Up @@ -32,4 +32,4 @@ jobs:
TESTCONTAINERS_RYUK_DISABLED: true
run: |
export DOCKER_IMAGE=`echo "${DOCKER_REGISTRY_URL}/${DOCKER_REPOSITORY_PATH}/btcproxyd-jit" | sed -e 's#//#/#' -e 's#^/##'`
./gradlew check dockerPush --no-daemon -s --info --scan
./gradlew check dockerBuildxImage --no-daemon -s --info --scan
18 changes: 16 additions & 2 deletions build.gradle
Original file line number Diff line number Diff line change
Expand Up @@ -97,6 +97,9 @@ test {
environment(['MICRONAUT_CONFIG_FILES':''])
}

// TODO: See if we can use this HOW-TO to build AMD64 & ARM64: https://dev.to/cloudx/multi-arch-docker-images-the-easy-way-with-github-actions-4k54
// See also: https://github.com/bmuschko/gradle-docker-plugin/issues/967#issuecomment-1103768609

tasks.named("dockerfile") {
baseImage = "eclipse-temurin:17-jre-jammy"
}
Expand All @@ -109,7 +112,18 @@ dockerBuildNative {
images = ["${System.env.DOCKER_IMAGE ?: project.name}:$project.version"]
}

def registry = 'consensusj'
def jitImageName = "$project.name-jit"

// Build and Push btcproxyd-jit for ARM64 and AMD64 architectures
task dockerBuildxImage(type:Exec) {
group 'build'
description "Builds multiplatform image using 'docker buildx'"
dependsOn dockerfile, buildLayers
workingDir 'build/docker/main'
executable 'docker'
args = ['buildx', 'build', '--platform', 'linux/amd64,linux/arm64', '-t', "$registry/$jitImageName:$project.version", '-t', "$registry/$jitImageName:latest", '--push', '.']
}

apply from: 'gradle/asciidoctor.gradle'
apply from: 'gradle/github-pages.gradle'


2 changes: 1 addition & 1 deletion gradle.properties
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
btcProxyVersion = 0.3.15
btcProxyVersion = 0.3.17

useMavenLocal = false

Expand Down

0 comments on commit 75447c8

Please sign in to comment.