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:
commit
ee1ce34024
@ -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"]
|
||||||
|
@ -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 \
|
||||||
|
@ -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"]
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user