From 999a7e45dc0e4c2c79eb72873249a0ddeb4db6ad Mon Sep 17 00:00:00 2001 From: "Patrik J. Braun" Date: Wed, 17 Apr 2024 20:17:58 +0200 Subject: [PATCH] trying debian-bookworm --- .github/workflows/build.yml | 8 +++-- docker/debian-bookworm/Dockerfile.build | 44 +++++++++++++++++++++++++ 2 files changed, 49 insertions(+), 3 deletions(-) create mode 100644 docker/debian-bookworm/Dockerfile.build diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index c80ce9a4..7cf93eea 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -108,7 +108,7 @@ jobs: needs: [ create-release ] strategy: matrix: - container: [alpine, debian-buster, debian-bullseye ] + container: [alpine, debian-buster, debian-bullseye, debian-bookworm ] include: - container: alpine platforms: linux/amd64,linux/arm64,linux/arm/v7 @@ -116,6 +116,8 @@ jobs: platforms: linux/amd64,linux/arm64,linux/arm/v7 - container: debian-bullseye platforms: linux/amd64,linux/arm64,linux/arm/v7 + - container: debian-bookworm + platforms: linux/amd64,linux/arm64,linux/arm/v7 steps: - name: Checkout @@ -159,7 +161,7 @@ jobs: push: true tags: bpatrik/pigallery2:edge-${{ matrix.container }} - name: Push release on new Tag - if: ${{ startsWith(github.ref_type , 'tag') && !github.event.issue.pull_request && matrix.container != 'debian-bullseye'}} + if: ${{ startsWith(github.ref_type , 'tag') && !github.event.issue.pull_request && matrix.container != 'debian-bookworm'}} uses: docker/build-push-action@v5 with: context: . @@ -171,7 +173,7 @@ jobs: bpatrik/pigallery2:${{ github.ref_name }}-${{ matrix.container }} bpatrik/pigallery2:latest-${{ matrix.container }} - name: Push latest on new Tag - if: ${{ startsWith(github.ref_type, 'tag') && !github.event.issue.pull_request && matrix.container == 'debian-bullseye'}} + if: ${{ startsWith(github.ref_type, 'tag') && !github.event.issue.pull_request && matrix.container == 'debian-bookworm'}} uses: docker/build-push-action@v5 with: context: . diff --git a/docker/debian-bookworm/Dockerfile.build b/docker/debian-bookworm/Dockerfile.build new file mode 100644 index 00000000..94bc993e --- /dev/null +++ b/docker/debian-bookworm/Dockerfile.build @@ -0,0 +1,44 @@ +#-----------------BUILDER----------------- +#----------------------------------------- +FROM node:18-bookworm AS builder +RUN apt update && apt install -y --no-install-recommends libvips-dev python3 +COPY pigallery2-release /app +WORKDIR /app +RUN npm install --unsafe-perm --fetch-timeout=90000 +RUN mkdir -p /app/data/config && \ + mkdir -p /app/data/db && \ + mkdir -p /app/data/images && \ + mkdir -p /app/data/tmp + + +#-----------------MAIN-------------------- +#----------------------------------------- +FROM node:18-bookworm-slim AS main +WORKDIR /app +ENV NODE_ENV=production \ + # overrides only the default value of the settings (the actualy value can be overwritten through config.json) + default-Database-dbFolder=/app/data/db \ + default-Media-folder=/app/data/images \ + default-Media-tempFolder=/app/data/tmp \ + default-Extensions-folder=/app/data/config/extensions \ + # flagging dockerized environemnt + PI_DOCKER=true + +EXPOSE 80 +RUN apt-get update \ + && apt-get install -y --no-install-recommends ca-certificates wget ffmpeg libvips42 \ + && apt-get clean -q -y \ + && rm -rf /var/lib/apt/lists/* +COPY --from=builder /app /app +VOLUME ["/app/data/config", "/app/data/db", "/app/data/images", "/app/data/tmp"] + +# Run build time diagnostics to make sure the app would work after build is finished +RUN ["node", "./src/backend/index", "--expose-gc", "--run-diagnostics", "--config-path=/app/diagnostics-config.json"] +HEALTHCHECK --interval=40s --timeout=30s --retries=3 --start-period=60s \ + CMD wget --quiet --tries=1 --no-check-certificate --spider \ + http://localhost:80/heartbeat || exit 1 + +# after a extensive job (like video converting), pigallery calls gc, to clean up everthing as fast as possible +# Exec form entrypoint is need otherwise (using shell form) ENV variables are not properly passed down to the app +ENTRYPOINT ["node", "./src/backend/index", "--expose-gc", "--config-path=/app/data/config/config.json"] +