89 lines
2.9 KiB
Docker
89 lines
2.9 KiB
Docker
# the different stages of this Dockerfile are meant to be built into separate images
|
|
# https://docs.docker.com/compose/compose-file/#target
|
|
|
|
ARG PHP_VERSION=7.2
|
|
ARG NGINX_VERSION=1.15
|
|
|
|
### NGINX
|
|
FROM nginx:${NGINX_VERSION}-alpine AS symfony_docker_nginx
|
|
|
|
COPY docker/nginx/conf.d /etc/nginx/conf.d/
|
|
COPY public /srv/app/public/
|
|
|
|
### H2 PROXY
|
|
FROM alpine:latest AS symfony_docker_h2-proxy-cert
|
|
|
|
RUN apk add --no-cache openssl
|
|
|
|
# Use this self-generated certificate only in dev, IT IS NOT SECURE!
|
|
RUN openssl genrsa -des3 -passout pass:NotSecure -out server.pass.key 2048
|
|
RUN openssl rsa -passin pass:NotSecure -in server.pass.key -out server.key
|
|
RUN rm server.pass.key
|
|
RUN openssl req -new -passout pass:NotSecure -key server.key -out server.csr \
|
|
-subj '/C=SS/ST=SS/L=Gotham City/O=Symfony/CN=localhost'
|
|
RUN openssl x509 -req -sha256 -days 365 -in server.csr -signkey server.key -out server.crt
|
|
|
|
FROM nginx:${NGINX_VERSION}-alpine AS symfony_docker_h2-proxy
|
|
|
|
RUN mkdir -p /etc/nginx/ssl/
|
|
COPY --from=symfony_docker_h2-proxy-cert server.key server.crt /etc/nginx/ssl/
|
|
COPY ./docker/h2-proxy/default.conf /etc/nginx/conf.d/default.conf
|
|
|
|
### PHP
|
|
FROM php:${PHP_VERSION}-fpm-alpine AS symfony_docker_php
|
|
|
|
RUN apk add --no-cache --virtual .persistent-deps \
|
|
git \
|
|
icu-libs \
|
|
zlib
|
|
|
|
ENV APCU_VERSION 5.1.12
|
|
RUN set -eux \
|
|
&& apk add --no-cache --virtual .build-deps \
|
|
$PHPIZE_DEPS \
|
|
icu-dev \
|
|
zlib-dev \
|
|
&& docker-php-ext-install \
|
|
intl \
|
|
zip \
|
|
&& pecl install \
|
|
apcu-${APCU_VERSION} \
|
|
&& docker-php-ext-enable --ini-name 20-apcu.ini apcu \
|
|
&& docker-php-ext-enable --ini-name 05-opcache.ini opcache \
|
|
&& apk del .build-deps
|
|
|
|
RUN ln -s $PHP_INI_DIR/php.ini-production $PHP_INI_DIR/php.ini
|
|
COPY docker/app/conf.d/symfony.ini $PHP_INI_DIR/conf.d/symfony.ini
|
|
COPY --from=composer:latest /usr/bin/composer /usr/bin/composer
|
|
COPY docker/app/docker-entrypoint.sh /usr/local/bin/docker-app-entrypoint
|
|
RUN chmod +x /usr/local/bin/docker-app-entrypoint
|
|
|
|
WORKDIR /srv/app
|
|
ENTRYPOINT ["docker-app-entrypoint"]
|
|
CMD ["php-fpm"]
|
|
|
|
# https://getcomposer.org/doc/03-cli.md#composer-allow-superuser
|
|
ENV COMPOSER_ALLOW_SUPERUSER 1
|
|
|
|
# Use prestissimo to speed up builds
|
|
RUN composer global require "hirak/prestissimo:^0.3" --prefer-dist --no-progress --no-suggest --optimize-autoloader --classmap-authoritative --no-interaction
|
|
|
|
# Allow to use development versions of Symfony
|
|
ARG STABILITY="stable"
|
|
ENV STABILITY ${STABILITY:-stable}
|
|
|
|
# Allow to select skeleton version
|
|
ARG SYMFONY_VERSION=""
|
|
|
|
# Download the Symfony skeleton and leverage Docker cache layers
|
|
RUN composer create-project "symfony/skeleton ${SYMFONY_VERSION}" . --stability=$STABILITY --prefer-dist --no-dev --no-progress --no-scripts --no-plugins --no-interaction
|
|
|
|
###> recipes ###
|
|
###< recipes ###
|
|
|
|
COPY . .
|
|
|
|
RUN mkdir -p var/cache var/logs var/sessions \
|
|
&& composer install --prefer-dist --no-dev --no-scripts --no-progress --no-suggest --classmap-authoritative --no-interaction \
|
|
&& chown -R www-data var
|