Compare commits

...

2 commits

Author SHA1 Message Date
Imbus
eca82edf4f Updated just targets 2024-02-12 18:56:49 +01:00
Imbus
5c1b810da1 Multi-stage container build for smaller image size 2024-02-12 18:56:26 +01:00
2 changed files with 21 additions and 6 deletions

View file

@ -6,6 +6,7 @@ build-container-release:
# Builds a release container and runs it # Builds a release container and runs it
start-release: build-container-release remove-podman-containers start-release: build-container-release remove-podman-containers
podman run -d -e DATABASE_URL=sqlite:release.db -p 8080:8080 --name ttime ttime-server podman run -d -e DATABASE_URL=sqlite:release.db -p 8080:8080 --name ttime ttime-server
@echo "Started production ttime-server on http://localhost:8080"
# Removes and stops any containers related to the project # Removes and stops any containers related to the project
[private] [private]
@ -14,7 +15,7 @@ remove-podman-containers:
# Saves the release container to a tarball, pigz is just gzip but multithreaded # Saves the release container to a tarball, pigz is just gzip but multithreaded
save-release: build-container-release save-release: build-container-release
podman save --format=oci-archive ttime-server | pigz -9 > ttime-server-pigz.tar.gz podman save --format=oci-archive ttime-server | pigz -9 > ttime-server.tar.gz
# Loads the release container from a tarball # Loads the release container from a tarball
load-release file: load-release file:
@ -25,5 +26,6 @@ clean: remove-podman-containers
podman image rm -f ttime-server podman image rm -f ttime-server
rm -rf frontend/dist rm -rf frontend/dist
rm -rf frontend/node_modules rm -rf frontend/node_modules
rm ttime-server.tar.gz
cd backend && make clean cd backend && make clean
@echo "Cleaned up!" @echo "Cleaned up!"

View file

@ -2,26 +2,39 @@
# We use node:latest as the base image. # We use node:latest as the base image.
# Essentially we build the frontend SPA with vite and # Essentially we build the frontend SPA with vite and
# make it available in the public directory. # make it available in the public directory.
FROM docker.io/node:latest as client FROM docker.io/node:alpine as client
WORKDIR /build WORKDIR /build
ADD frontend /build ADD frontend /build
RUN npm install RUN npm install
RUN npm run build RUN npm run build
# Builds the server in an isolated stage # Builds the server in an isolated stage
FROM docker.io/golang:latest as go FROM docker.io/golang:alpine as go
RUN apk add gcompat
RUN apk add gcc
RUN apk add musl-dev
ADD backend /build ADD backend /build
WORKDIR /build WORKDIR /build
# Copy the frontend SPA build into public
COPY --from=client /build/dist /build/static
# Get the dependencies # Get the dependencies
RUN go mod download RUN go mod download
# RUN go build -o server # RUN go build -o server
RUN CGO_ENABLED=1 GOOS=linux go build -a -installsuffix cgo -o ./server ./cmd/ RUN CGO_ENABLED=1 GOOS=linux go build -a -installsuffix cgo -o ./server ./cmd/
# The final stage for building a minimal image
FROM docker.io/alpine:latest as runner
WORKDIR /app
# Copy the frontend SPA build into public
COPY --from=client /build/dist /app/static
# Copy the server binary
COPY --from=go /build/server /app/server
# Copy the migration scripts
COPY --from=go /build/migrations /app/migrations
# Expose port 8080 # Expose port 8080
EXPOSE 8080 EXPOSE 8080