Dockerfile 2.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566
  1. # This is a Dockerfile intended to be built using `docker buildx`
  2. # for multi-arch support. Building with `docker build` may have unexpected results.
  3. # This file assumes that the frontend has been built using ./scripts/frontend-build
  4. FROM nginxproxymanager/testca AS testca
  5. FROM letsencrypt/pebble AS pebbleca
  6. FROM nginxproxymanager/nginx-full:certbot-node
  7. ARG TARGETPLATFORM
  8. ARG BUILD_VERSION
  9. ARG BUILD_COMMIT
  10. ARG BUILD_DATE
  11. # See: https://github.com/just-containers/s6-overlay/blob/master/README.md
  12. ENV SUPPRESS_NO_CONFIG_WARNING=1 \
  13. S6_BEHAVIOUR_IF_STAGE2_FAILS=1 \
  14. S6_CMD_WAIT_FOR_SERVICES_MAXTIME=0 \
  15. S6_FIX_ATTRS_HIDDEN=1 \
  16. S6_KILL_FINISH_MAXTIME=10000 \
  17. S6_VERBOSITY=1 \
  18. NODE_ENV=production \
  19. NPM_BUILD_VERSION="${BUILD_VERSION}" \
  20. NPM_BUILD_COMMIT="${BUILD_COMMIT}" \
  21. NPM_BUILD_DATE="${BUILD_DATE}" \
  22. NODE_OPTIONS="--openssl-legacy-provider"
  23. RUN echo "fs.file-max = 65535" > /etc/sysctl.conf \
  24. && apt-get update \
  25. && apt-get install -y --no-install-recommends jq logrotate \
  26. && apt-get clean \
  27. && rm -rf /var/lib/apt/lists/*
  28. # s6 overlay
  29. COPY docker/scripts/install-s6 /tmp/install-s6
  30. RUN /tmp/install-s6 "${TARGETPLATFORM}" && rm -f /tmp/install-s6
  31. EXPOSE 80 81 443
  32. COPY backend /app
  33. COPY frontend/dist /app/frontend
  34. COPY global /app/global
  35. WORKDIR /app
  36. RUN yarn install \
  37. && yarn cache clean
  38. # add late to limit cache-busting by modifications
  39. COPY docker/rootfs /
  40. COPY --from=pebbleca /test/certs/pebble.minica.pem /etc/ssl/certs/pebble.minica.pem
  41. COPY --from=testca /home/step/certs/root_ca.crt /etc/ssl/certs/NginxProxyManager.crt
  42. # Remove frontend service not required for prod, dev nginx config as well
  43. RUN rm -rf /etc/s6-overlay/s6-rc.d/user/contents.d/frontend /etc/nginx/conf.d/dev.conf \
  44. && chmod 644 /etc/logrotate.d/nginx-proxy-manager
  45. VOLUME [ "/data" ]
  46. ENTRYPOINT [ "/init" ]
  47. LABEL org.label-schema.schema-version="1.0" \
  48. org.label-schema.license="MIT" \
  49. org.label-schema.name="nginx-proxy-manager" \
  50. org.label-schema.description="Docker container for managing Nginx proxy hosts with a simple, powerful interface " \
  51. org.label-schema.url="https://github.com/jc21/nginx-proxy-manager" \
  52. org.label-schema.vcs-url="https://github.com/jc21/nginx-proxy-manager.git" \
  53. org.label-schema.cmd="docker run --rm -ti jc21/nginx-proxy-manager:latest"