feat: use docker buildx to build multiarch images
This commit is contained in:
parent
c47e07f9b0
commit
a6e214b654
@ -1,4 +1,7 @@
|
|||||||
files/
|
files/
|
||||||
|
dist/
|
||||||
|
logs/
|
||||||
|
|
||||||
Dockerfile
|
Dockerfile
|
||||||
docker-manifest.tmpl
|
docker-manifest.tmpl
|
||||||
docker-manifest-unstable.tmpl
|
docker-manifest-unstable.tmpl
|
||||||
|
194
.drone.yml
194
.drone.yml
@ -627,102 +627,11 @@ steps:
|
|||||||
---
|
---
|
||||||
kind: pipeline
|
kind: pipeline
|
||||||
type: docker
|
type: docker
|
||||||
name: docker-arm-release
|
name: docker-release
|
||||||
|
|
||||||
depends_on:
|
depends_on:
|
||||||
- testing
|
- testing
|
||||||
|
|
||||||
platform:
|
|
||||||
os: linux
|
|
||||||
arch: arm64
|
|
||||||
|
|
||||||
trigger:
|
|
||||||
ref:
|
|
||||||
- refs/heads/main
|
|
||||||
- "refs/tags/**"
|
|
||||||
|
|
||||||
steps:
|
|
||||||
- name: fetch-tags
|
|
||||||
image: docker:git
|
|
||||||
commands:
|
|
||||||
- git fetch --tags
|
|
||||||
|
|
||||||
- name: docker-arm-unstable
|
|
||||||
image: plugins/docker:linux-arm
|
|
||||||
pull: true
|
|
||||||
settings:
|
|
||||||
username:
|
|
||||||
from_secret: docker_username
|
|
||||||
password:
|
|
||||||
from_secret: docker_password
|
|
||||||
repo: vikunja/api
|
|
||||||
tags: unstable-linux-arm
|
|
||||||
dockerfile: Dockerfile.arm32
|
|
||||||
depends_on: [ fetch-tags ]
|
|
||||||
when:
|
|
||||||
ref:
|
|
||||||
- refs/heads/main
|
|
||||||
|
|
||||||
- name: docker-arm
|
|
||||||
image: plugins/docker:linux-arm
|
|
||||||
pull: true
|
|
||||||
settings:
|
|
||||||
username:
|
|
||||||
from_secret: docker_username
|
|
||||||
password:
|
|
||||||
from_secret: docker_password
|
|
||||||
repo: vikunja/api
|
|
||||||
auto_tag: true
|
|
||||||
auto_tag_suffix: linux-arm
|
|
||||||
dockerfile: Dockerfile.arm32
|
|
||||||
depends_on: [ fetch-tags ]
|
|
||||||
when:
|
|
||||||
ref:
|
|
||||||
- "refs/tags/**"
|
|
||||||
|
|
||||||
- name: docker-arm64-unstable
|
|
||||||
image: plugins/docker:linux-arm64
|
|
||||||
pull: true
|
|
||||||
settings:
|
|
||||||
username:
|
|
||||||
from_secret: docker_username
|
|
||||||
password:
|
|
||||||
from_secret: docker_password
|
|
||||||
repo: vikunja/api
|
|
||||||
tags: unstable-linux-arm64
|
|
||||||
depends_on: [ fetch-tags ]
|
|
||||||
when:
|
|
||||||
ref:
|
|
||||||
- refs/heads/main
|
|
||||||
|
|
||||||
- name: docker-arm64
|
|
||||||
image: plugins/docker:linux-arm64
|
|
||||||
pull: true
|
|
||||||
settings:
|
|
||||||
username:
|
|
||||||
from_secret: docker_username
|
|
||||||
password:
|
|
||||||
from_secret: docker_password
|
|
||||||
repo: vikunja/api
|
|
||||||
auto_tag: true
|
|
||||||
auto_tag_suffix: linux-arm64
|
|
||||||
depends_on: [ fetch-tags ]
|
|
||||||
when:
|
|
||||||
ref:
|
|
||||||
- "refs/tags/**"
|
|
||||||
|
|
||||||
---
|
|
||||||
kind: pipeline
|
|
||||||
type: docker
|
|
||||||
name: docker-amd64-release
|
|
||||||
|
|
||||||
depends_on:
|
|
||||||
- testing
|
|
||||||
|
|
||||||
platform:
|
|
||||||
os: linux
|
|
||||||
arch: amd64
|
|
||||||
|
|
||||||
trigger:
|
trigger:
|
||||||
ref:
|
ref:
|
||||||
- refs/heads/main
|
- refs/heads/main
|
||||||
@ -735,7 +644,8 @@ steps:
|
|||||||
- git fetch --tags
|
- git fetch --tags
|
||||||
|
|
||||||
- name: docker-unstable
|
- name: docker-unstable
|
||||||
image: plugins/docker:linux-amd64
|
image: thegeeklab/drone-docker-buildx
|
||||||
|
privileged: true
|
||||||
pull: true
|
pull: true
|
||||||
settings:
|
settings:
|
||||||
username:
|
username:
|
||||||
@ -743,86 +653,36 @@ steps:
|
|||||||
password:
|
password:
|
||||||
from_secret: docker_password
|
from_secret: docker_password
|
||||||
repo: vikunja/api
|
repo: vikunja/api
|
||||||
tags: unstable-linux-amd64
|
|
||||||
depends_on: [ fetch-tags ]
|
|
||||||
when:
|
|
||||||
ref:
|
|
||||||
- refs/heads/main
|
|
||||||
|
|
||||||
- name: docker
|
|
||||||
image: plugins/docker:linux-amd64
|
|
||||||
pull: true
|
|
||||||
settings:
|
|
||||||
username:
|
|
||||||
from_secret: docker_username
|
|
||||||
password:
|
|
||||||
from_secret: docker_password
|
|
||||||
repo: vikunja/api
|
|
||||||
auto_tag: true
|
|
||||||
auto_tag_suffix: linux-amd64
|
|
||||||
depends_on: [ fetch-tags ]
|
|
||||||
when:
|
|
||||||
ref:
|
|
||||||
- "refs/tags/**"
|
|
||||||
|
|
||||||
---
|
|
||||||
kind: pipeline
|
|
||||||
type: docker
|
|
||||||
name: docker-manifest
|
|
||||||
|
|
||||||
trigger:
|
|
||||||
ref:
|
|
||||||
- refs/heads/main
|
|
||||||
- "refs/tags/**"
|
|
||||||
|
|
||||||
depends_on:
|
|
||||||
- docker-amd64-release
|
|
||||||
- docker-arm-release
|
|
||||||
|
|
||||||
steps:
|
|
||||||
- name: manifest-unstable
|
|
||||||
pull: always
|
|
||||||
image: plugins/manifest
|
|
||||||
settings:
|
|
||||||
tags: unstable
|
tags: unstable
|
||||||
ignore_missing: true
|
platforms:
|
||||||
spec: docker-manifest-unstable.tmpl
|
- linux/386
|
||||||
password:
|
- linux/amd64
|
||||||
from_secret: docker_password
|
- linux/arm/v6
|
||||||
username:
|
- linux/arm/v7
|
||||||
from_secret: docker_username
|
- linux/arm64/v8
|
||||||
|
depends_on: [ fetch-tags ]
|
||||||
when:
|
when:
|
||||||
ref:
|
ref:
|
||||||
- refs/heads/main
|
- refs/heads/main
|
||||||
|
|
||||||
- name: manifest-release
|
- name: docker-release
|
||||||
pull: always
|
image: thegeeklab/drone-docker-buildx
|
||||||
image: plugins/manifest
|
privileged: true
|
||||||
|
pull: true
|
||||||
settings:
|
settings:
|
||||||
|
username:
|
||||||
|
from_secret: docker_username
|
||||||
|
password:
|
||||||
|
from_secret: docker_password
|
||||||
|
repo: vikunja/api
|
||||||
auto_tag: true
|
auto_tag: true
|
||||||
ignore_missing: true
|
platforms:
|
||||||
spec: docker-manifest.tmpl
|
- linux/386
|
||||||
password:
|
- linux/amd64
|
||||||
from_secret: docker_password
|
- linux/arm/v6
|
||||||
username:
|
- linux/arm/v7
|
||||||
from_secret: docker_username
|
- linux/arm64/v8
|
||||||
when:
|
depends_on: [ fetch-tags ]
|
||||||
ref:
|
|
||||||
- "refs/tags/**"
|
|
||||||
|
|
||||||
- name: manifest-release-latest
|
|
||||||
pull: always
|
|
||||||
image: plugins/manifest
|
|
||||||
depends_on:
|
|
||||||
- clone
|
|
||||||
settings:
|
|
||||||
tags: latest
|
|
||||||
ignore_missing: true
|
|
||||||
spec: docker-manifest.tmpl
|
|
||||||
password:
|
|
||||||
from_secret: docker_password
|
|
||||||
username:
|
|
||||||
from_secret: docker_username
|
|
||||||
when:
|
when:
|
||||||
ref:
|
ref:
|
||||||
- "refs/tags/**"
|
- "refs/tags/**"
|
||||||
@ -861,6 +721,6 @@ steps:
|
|||||||
- failure
|
- failure
|
||||||
---
|
---
|
||||||
kind: signature
|
kind: signature
|
||||||
hmac: 5500acb776acae4975592637767035c45af277f1f56c8d10ffd99f38761cd5c8
|
hmac: 9af6de023ca9e78e0b485948b58764007cb169ee3cbcdd9e909c2049f5d20740
|
||||||
|
|
||||||
...
|
...
|
||||||
|
12
Dockerfile
12
Dockerfile
@ -1,9 +1,9 @@
|
|||||||
|
|
||||||
##############
|
##############
|
||||||
# Build stage
|
# Build stage
|
||||||
FROM golang:1.19-alpine AS build-env
|
FROM --platform=$BUILDPLATFORM techknowlogick/xgo:latest AS build-env
|
||||||
|
|
||||||
RUN apk --no-cache add build-base git && \
|
RUN \
|
||||||
go install github.com/magefile/mage@latest && \
|
go install github.com/magefile/mage@latest && \
|
||||||
mv /go/bin/mage /usr/local/go/bin
|
mv /go/bin/mage /usr/local/go/bin
|
||||||
|
|
||||||
@ -13,9 +13,11 @@ ARG VIKUNJA_VERSION
|
|||||||
COPY . /go/src/code.vikunja.io/api
|
COPY . /go/src/code.vikunja.io/api
|
||||||
WORKDIR /go/src/code.vikunja.io/api
|
WORKDIR /go/src/code.vikunja.io/api
|
||||||
|
|
||||||
|
ARG TARGETOS TARGETARCH TARGETVARIANT
|
||||||
# Checkout version if set
|
# Checkout version if set
|
||||||
RUN if [ -n "${VIKUNJA_VERSION}" ]; then git checkout "${VIKUNJA_VERSION}"; fi \
|
RUN if [ -n "${VIKUNJA_VERSION}" ]; then git checkout "${VIKUNJA_VERSION}"; fi && \
|
||||||
&& mage build:clean build
|
mage build:clean && \
|
||||||
|
mage release:xgo $TARGETOS/$TARGETARCH/$TARGETVARIANT
|
||||||
|
|
||||||
###################
|
###################
|
||||||
# The actual image
|
# The actual image
|
||||||
@ -25,7 +27,7 @@ FROM alpine:3.16
|
|||||||
LABEL maintainer="maintainers@vikunja.io"
|
LABEL maintainer="maintainers@vikunja.io"
|
||||||
|
|
||||||
WORKDIR /app/vikunja/
|
WORKDIR /app/vikunja/
|
||||||
COPY --from=build-env /go/src/code.vikunja.io/api/vikunja .
|
COPY --from=build-env /build/vikunja-* vikunja
|
||||||
ENV VIKUNJA_SERVICE_ROOTPATH=/app/vikunja/
|
ENV VIKUNJA_SERVICE_ROOTPATH=/app/vikunja/
|
||||||
|
|
||||||
# Dynamic permission changing stuff
|
# Dynamic permission changing stuff
|
||||||
|
@ -1,48 +0,0 @@
|
|||||||
|
|
||||||
##############
|
|
||||||
# Build stage
|
|
||||||
FROM golang:1.19-buster AS build-env
|
|
||||||
|
|
||||||
RUN go install github.com/magefile/mage@latest && \
|
|
||||||
mv /go/bin/mage /usr/local/go/bin
|
|
||||||
|
|
||||||
ARG VIKUNJA_VERSION
|
|
||||||
|
|
||||||
# Setup repo
|
|
||||||
COPY . /go/src/code.vikunja.io/api
|
|
||||||
WORKDIR /go/src/code.vikunja.io/api
|
|
||||||
|
|
||||||
# Checkout version if set
|
|
||||||
RUN if [ -n "${VIKUNJA_VERSION}" ]; then git checkout "${VIKUNJA_VERSION}"; fi \
|
|
||||||
&& mage build:clean build
|
|
||||||
|
|
||||||
###################
|
|
||||||
# The actual image
|
|
||||||
# Note: I wanted to use the scratch image here, but unfortunatly the go-sqlite bindings require cgo and
|
|
||||||
# because of this, the container would not start when I compiled the image without cgo.
|
|
||||||
# We're using debian as a base image here because the latest alpine image does not work with arm.
|
|
||||||
FROM debian:buster-slim
|
|
||||||
LABEL maintainer="maintainers@vikunja.io"
|
|
||||||
|
|
||||||
WORKDIR /app/vikunja/
|
|
||||||
COPY --from=build-env /go/src/code.vikunja.io/api/vikunja .
|
|
||||||
ENV VIKUNJA_SERVICE_ROOTPATH=/app/vikunja/
|
|
||||||
|
|
||||||
# Dynamic permission changing stuff
|
|
||||||
ENV PUID 1000
|
|
||||||
ENV PGID 1000
|
|
||||||
RUN addgroup --gid ${PGID} vikunja && \
|
|
||||||
chown ${PUID} -R /app/vikunja && \
|
|
||||||
useradd --shell /bin/sh --gid vikunja --uid ${PUID} --home-dir /app/vikunja vikunja
|
|
||||||
COPY run.sh /run.sh
|
|
||||||
|
|
||||||
# Fix time zone settings not working
|
|
||||||
RUN apt-get update && apt-get install -y tzdata && apt-get clean
|
|
||||||
|
|
||||||
# Files permissions
|
|
||||||
RUN mkdir /app/vikunja/files && \
|
|
||||||
chown -R vikunja /app/vikunja/files
|
|
||||||
VOLUME /app/vikunja/files
|
|
||||||
|
|
||||||
CMD ["/run.sh"]
|
|
||||||
EXPOSE 3456
|
|
@ -1,17 +0,0 @@
|
|||||||
image: vikunja/api:unstable
|
|
||||||
manifests:
|
|
||||||
-
|
|
||||||
image: vikunja/api:unstable-linux-amd64
|
|
||||||
platform:
|
|
||||||
architecture: amd64
|
|
||||||
os: linux
|
|
||||||
-
|
|
||||||
image: vikunja/api:unstable-linux-arm64
|
|
||||||
platform:
|
|
||||||
architecture: arm64
|
|
||||||
os: linux
|
|
||||||
-
|
|
||||||
image: vikunja/api:unstable-linux-arm
|
|
||||||
platform:
|
|
||||||
architecture: arm
|
|
||||||
os: linux
|
|
@ -1,23 +0,0 @@
|
|||||||
image: vikunja/api:{{#if build.tag}}{{trimPrefix "v" build.tag}}{{else}}latest{{/if}}
|
|
||||||
{{#if build.tags}}
|
|
||||||
tags:
|
|
||||||
{{#each build.tags}}
|
|
||||||
- {{this}}
|
|
||||||
{{/each}}
|
|
||||||
{{/if}}
|
|
||||||
manifests:
|
|
||||||
-
|
|
||||||
image: vikunja/api:{{#if build.tag}}{{trimPrefix "v" build.tag}}-{{/if}}linux-amd64
|
|
||||||
platform:
|
|
||||||
architecture: amd64
|
|
||||||
os: linux
|
|
||||||
-
|
|
||||||
image: vikunja/api:{{#if build.tag}}{{trimPrefix "v" build.tag}}-{{/if}}linux-arm64
|
|
||||||
platform:
|
|
||||||
architecture: arm64
|
|
||||||
os: linux
|
|
||||||
-
|
|
||||||
image: vikunja/api:{{#if build.tag}}{{trimPrefix "v" build.tag}}-{{/if}}linux-arm
|
|
||||||
platform:
|
|
||||||
architecture: arm
|
|
||||||
os: linux
|
|
14
magefile.go
14
magefile.go
@ -546,6 +546,20 @@ func (Release) Darwin() error {
|
|||||||
return runXgo("darwin-10.15/*")
|
return runXgo("darwin-10.15/*")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (Release) Xgo(target string) error {
|
||||||
|
parts := strings.Split(target, "/")
|
||||||
|
if len(parts) < 2 {
|
||||||
|
return fmt.Errorf("invalid target")
|
||||||
|
}
|
||||||
|
|
||||||
|
variant := ""
|
||||||
|
if len(parts) > 2 && parts[2] != "" {
|
||||||
|
variant = "-" + strings.ReplaceAll(parts[2], "v", "")
|
||||||
|
}
|
||||||
|
|
||||||
|
return runXgo(parts[0] + "/" + parts[1] + variant)
|
||||||
|
}
|
||||||
|
|
||||||
// Compresses the built binaries in dist/binaries/ to reduce their filesize
|
// Compresses the built binaries in dist/binaries/ to reduce their filesize
|
||||||
func (Release) Compress(ctx context.Context) error {
|
func (Release) Compress(ctx context.Context) error {
|
||||||
// $(foreach file,$(filter-out $(wildcard $(wildcard $(DIST)/binaries/$(EXECUTABLE)-*mips*)),$(wildcard $(DIST)/binaries/$(EXECUTABLE)-*)), upx -9 $(file);)
|
// $(foreach file,$(filter-out $(wildcard $(wildcard $(DIST)/binaries/$(EXECUTABLE)-*mips*)),$(wildcard $(DIST)/binaries/$(EXECUTABLE)-*)), upx -9 $(file);)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user