Docker multiplatform build support. Pending CI workflow test

This commit is contained in:
PathToLife 2025-02-13 20:57:45 +13:00
parent e48fc4c8d8
commit f8b613b4e7
No known key found for this signature in database
GPG key ID: EC6B08753A67F776
2 changed files with 26 additions and 5 deletions

View file

@ -61,7 +61,7 @@ jobs:
tags: ${{ steps.image-metadata.outputs.tags }}
labels: ${{ steps.image-metadata.outputs.labels }}
containerfiles: ./Dockerfile
platforms: linux/amd64
platforms: linux/amd64,linux/arm64,linux/arm/v7
oci: true
# Webpack seems to use a lot of open files, increase the max open file limit to accomodate.
extra-args: |

View file

@ -1,9 +1,30 @@
FROM node:18-alpine AS build
#####################################
# Build the app to a static website #
#####################################
# Modifier --platform=$BUILDPLATFORM limits the platform to "BUILDPLATFORM" during buildx multi-platform builds
# This is because npm "chromedriver" package is not compatiable with all platforms
# For more info see: https://docs.docker.com/build/building/multi-platform/#cross-compilation
FROM --platform=$BUILDPLATFORM node:18-alpine AS builder
WORKDIR /app
COPY package.json .
COPY package-lock.json .
# Install dependencies
# --ignore-scripts do not run grunt postinstall script as it depends on files other than package.json
RUN npm ci --ignore-scripts
# Build the app
COPY . .
RUN npm ci
# npm postinstall runs grunt, which depends on files other than package.json
RUN npm run postinstall
RUN npm run build
FROM nginx:1.25-alpine3.18 AS cyberchef
#########################################
# Package static build files into nginx #
#########################################
FROM nginx:stable-alpine AS cyberchef
COPY --from=build ./build/prod /usr/share/nginx/html/
COPY --from=builder /app/build/prod /usr/share/nginx/html/