1
0
mirror of https://github.com/bpatrik/pigallery2.git synced 2024-12-12 11:15:22 +02:00

Merge pull request #195 from zertrin/dockerfile-updates-1

Update Dockerfiles
This commit is contained in:
Patrik J. Braun 2020-10-26 21:17:37 +01:00 committed by GitHub
commit ee1ce34024
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 41 additions and 35 deletions

View File

@ -14,7 +14,7 @@ RUN mkdir -p /app/data/config && \
#-----------------MAIN-------------------- #-----------------MAIN--------------------
#----------------------------------------- #-----------------------------------------
FROM node:12-alpine3.11 as main FROM node:12-alpine3.11 AS main
WORKDIR /app WORKDIR /app
ENV NODE_ENV=production \ ENV NODE_ENV=production \
# overrides only the default value of the settings (the actualy value can be overwritten through config.json) # overrides only the default value of the settings (the actualy value can be overwritten through config.json)
@ -24,7 +24,6 @@ ENV NODE_ENV=production \
# flagging dockerized environemnt # flagging dockerized environemnt
PI_DOCKER=true PI_DOCKER=true
EXPOSE 80 EXPOSE 80
RUN apk add --update-cache --repository https://alpine.global.ssl.fastly.net/alpine/v3.11/community/ \ RUN apk add --update-cache --repository https://alpine.global.ssl.fastly.net/alpine/v3.11/community/ \
vips ffmpeg vips ffmpeg
@ -34,7 +33,6 @@ HEALTHCHECK --interval=40s --timeout=30s --retries=3 --start-period=60s \
CMD wget --quiet --tries=1 --no-check-certificate --spider \ CMD wget --quiet --tries=1 --no-check-certificate --spider \
http://localhost:80/heartbeat || exit 1 http://localhost:80/heartbeat || exit 1
# after a extensive job (like video converting), pigallery calls gc, to clean up everthing as fast as possible # 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 # 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"] ENTRYPOINT ["node", "./src/backend/index", "--expose-gc", "--config-path=/app/data/config/config.json"]

View File

@ -12,7 +12,7 @@ RUN mkdir -p /app/data/config && \
#-----------------MAIN-------------------- #-----------------MAIN--------------------
#----------------------------------------- #-----------------------------------------
FROM node:12-stretch-slim as main FROM node:12-stretch-slim AS main
WORKDIR /app WORKDIR /app
ENV NODE_ENV=production \ ENV NODE_ENV=production \
# overrides only the default value of the settings (the actualy value can be overwritten through config.json) # overrides only the default value of the settings (the actualy value can be overwritten through config.json)
@ -22,14 +22,11 @@ ENV NODE_ENV=production \
# flagging dockerized environemnt # flagging dockerized environemnt
PI_DOCKER=true PI_DOCKER=true
# after a extensive job (like video converting), pigallery calls gc, to clean up everthing as fast as possible
# This trick is needed as entrypoint in exec form does not support ENV variables
# and in shell form ENV variables were not properly passed to pigallry2
#RUN echo -e '#!/bin/bash \n node ./src/backend/index --expose-gc --config-path=${CONFIG_FILE}' > ./entrypoint.sh && \
# chmod +x ./entrypoint.sh
EXPOSE 80 EXPOSE 80
RUN apt-get update && apt-get install -y ffmpeg RUN apt-get update \
&& apt-get install -y --no-install-recommends ca-certificates wget ffmpeg \
&& apt-get clean -q -y \
&& rm -rf /var/lib/apt/lists/*
COPY --from=builder /app /app COPY --from=builder /app /app
VOLUME ["/app/data/config", "/app/data/db", "/app/data/images", "/app/data/tmp"] VOLUME ["/app/data/config", "/app/data/db", "/app/data/images", "/app/data/tmp"]
HEALTHCHECK --interval=40s --timeout=30s --retries=3 --start-period=60s \ HEALTHCHECK --interval=40s --timeout=30s --retries=3 --start-period=60s \

View File

@ -1,32 +1,43 @@
FROM node:12-stretch AS BUILDER #-----------------BUILDER-----------------
#-----------------------------------------
FROM node:12-stretch AS builder
# LABEL maintainer="Patrik J. Braun" # LABEL maintainer="Patrik J. Braun"
# copying only package{-lock}.json to make node_modules cachable # copying only package{-lock}.json to make node_modules cachable
RUN git clone https://github.com/bpatrik/pigallery2.git /build RUN git clone https://github.com/bpatrik/pigallery2.git /build
WORKDIR /build WORKDIR /build
RUN set -x && npm install --unsafe-perm && \ RUN npm install --unsafe-perm \
mkdir -p /build/release/data/config && \ && mkdir -p /build/release/data/config \
mkdir -p /build/release/data/db && \ && mkdir -p /build/release/data/db \
mkdir -p /build/release/data/images && \ && mkdir -p /build/release/data/images \
mkdir -p /build/release/data/tmp && \ && mkdir -p /build/release/data/tmp \
npm run create-release && \ && npm run create-release \
cd /build/release && npm install --unsafe-perm && cd /build/release \
&& npm install --unsafe-perm
#-----------------MAIN--------------------
FROM node:12-stretch-slim #-----------------------------------------
FROM node:12-stretch-slim AS main
WORKDIR /app WORKDIR /app
ENV NODE_ENV=production \ ENV NODE_ENV=production \
CONFIG_FILE=/app/data/config/config.json \ # overrides only the default value of the settings (the actualy value can be overwritten through config.json)
Server-Database-dbFolder=/app/data/db \ default-Server-Database-dbFolder=/app/data/db \
Server-Media-folder=/app/data/images \ default-Server-Media-folder=/app/data/images \
Server-Media-tempFolder=/app/data/tmp default-Server-Media-tempFolder=/app/data/tmp \
ENTRYPOINT ["npm", "start", "--", \ # flagging dockerized environemnt
# after a extensive job (like video converting), pigallery calls gc, to clean up everthing as fast as possible PI_DOCKER=true
"--expose-gc", \
"--config-path=$CONFIG_FILE"] EXPOSE 80
EXPOSE 80 RUN apt-get update \
COPY --from=BUILDER /build/release /app && apt-get install -y --no-install-recommends ca-certificates wget ffmpeg \
VOLUME ["/app/data/config", "/app/data/db", "/app/data/images", "/app/data/tmp"] && apt-get clean -q -y \
HEALTHCHECK --interval=30s --timeout=10s --retries=4 --start-period=60s \ && rm -rf /var/lib/apt/lists/*
CMD wget --quiet --tries=1 --no-check-certificate --spider \ COPY --from=builder /build/release /app
http://localhost:80 || exit 1 VOLUME ["/app/data/config", "/app/data/db", "/app/data/images", "/app/data/tmp"]
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"]