server/bin/container/Dockerfile
Ipstenu (Mika Epstein) 9562cf4d3f
Build 4 (#73)
Signed-off-by: Mika Ipstenu Epstein <ipstenu@ipstenu.org>
Signed-off-by: Me
2025-12-22 17:07:11 -08:00

58 lines
1.3 KiB
Docker

ARG ALPINE_VERSION=3.21
ARG SRC_DIR
FROM alpine:${ALPINE_VERSION}
# Setup document root
WORKDIR /app
# Install packages and remove default server definition
RUN apk add --no-cache \
curl \
php84 \
php84-ctype \
php84-curl \
php84-dom \
php84-fileinfo \
php84-fpm \
php84-gd \
php84-intl \
php84-mbstring \
php84-mysqli \
php84-opcache \
php84-openssl \
php84-phar \
php84-session \
php84-tokenizer \
php84-xml \
php84-xmlreader \
php84-xmlwriter \
php84-gmp \
php84-zip \
supervisor
# RUN ln -s /usr/bin/php84 /usr/bin/php
RUN ln -s /usr/sbin/php-fpm84 /usr/sbin/php-fpm
# Configure PHP-FPM
ENV PHP_INI_DIR=/etc/php84
COPY fpm-pool.conf ${PHP_INI_DIR}/php-fpm.d/www.conf
COPY php.ini ${PHP_INI_DIR}/conf.d/custom.ini
# Make sure files/folders needed by the processes are accessible when they run under the nobody user
RUN chown -R nobody:nobody /app /run
# Switch to use a non-root user from here on
USER nobody
# Add application
COPY --chown=nobody --from=src . /app/
# Expose the port nginx is reachable on
EXPOSE 9000
# Let supervisord start nginx & php-fpm
# CMD ["/usr/bin/supervisord", "-c", "/etc/supervisor/conf.d/supervisord.conf"]
CMD ["php-fpm", "-F"]
# Configure a healthcheck to validate that everything is up&running
# HEALTHCHECK --timeout=10s CMD curl --silent --fail http://127.0.0.1:8080/fpm-ping || exit 1