Dockerfile 3,9 ko
Newer Older
# the different stages of this Dockerfile are meant to be built into separate images
Teoh Han Hui's avatar
Teoh Han Hui a validé
# https://docs.docker.com/develop/develop-images/multistage-build/#stop-at-a-specific-build-stage
# https://docs.docker.com/compose/compose-file/#target

Teoh Han Hui's avatar
Teoh Han Hui a validé

# https://docs.docker.com/engine/reference/builder/#understand-how-arg-and-from-interact
Jérôme Deuchnord's avatar
Jérôme Deuchnord a validé
ARG PHP_VERSION=7.4
ARG OPENRESTY_VERSION=1.15.8.3
ARG VARNISH_VERSION=6.4
Teoh Han Hui's avatar
Teoh Han Hui a validé

# "php" stage
FROM php:${PHP_VERSION}-fpm-alpine AS api_platform_php
# persistent / runtime deps
RUN apk add --no-cache \
Ganon's avatar
Ganon a validé
		fcgi \
		file \
		gettext \
		git \
	;
Lctrs's avatar
Lctrs a validé
ARG APCU_VERSION=5.1.18
RUN set -eux; \
	apk add --no-cache --virtual .build-deps \
		libzip-dev \
		postgresql-dev \
		zlib-dev \
Jérôme Deuchnord's avatar
Jérôme Deuchnord a validé
	docker-php-ext-configure zip; \
	docker-php-ext-install -j$(nproc) \
	; \
	pecl install \
		apcu-${APCU_VERSION} \
	; \
	pecl clear-cache; \
	docker-php-ext-enable \
		apcu \
		opcache \
	; \
	\
	runDeps="$( \
		scanelf --needed --nobanner --format '%n#p' --recursive /usr/local/lib/php/extensions \
			| tr ',' '\n' \
			| sort -u \
			| awk 'system("[ -e /usr/local/lib/" $1 " ]") == 0 { next } { print "so:" $1 }' \
	)"; \
	apk add --no-cache --virtual .api-phpexts-rundeps $runDeps; \
	\
	apk del .build-deps
COPY --from=composer:latest /usr/bin/composer /usr/bin/composer
Ganon's avatar
Ganon a validé

Lctrs's avatar
Lctrs a validé
RUN ln -s $PHP_INI_DIR/php.ini-production $PHP_INI_DIR/php.ini
COPY docker/php/conf.d/api-platform.prod.ini $PHP_INI_DIR/conf.d/api-platform.ini
Ganon's avatar
Ganon a validé
RUN set -eux; \
	{ \
		echo '[www]'; \
		echo 'ping.path = /ping'; \
	} | tee /usr/local/etc/php-fpm.d/docker-healthcheck.conf

Kévin Dunglas's avatar
Kévin Dunglas a validé
# https://getcomposer.org/doc/03-cli.md#composer-allow-superuser
ENV COMPOSER_ALLOW_SUPERUSER=1
# install Symfony Flex globally to speed up download of Composer packages (parallelized prefetching)
Teoh Han Hui's avatar
Teoh Han Hui a validé
RUN set -eux; \
	composer global require "symfony/flex" --prefer-dist --no-progress --no-suggest --classmap-authoritative; \
	composer clear-cache
ENV PATH="${PATH}:/root/.composer/vendor/bin"
Kévin Dunglas's avatar
Kévin Dunglas a validé

WORKDIR /srv/api

# build for production
ARG APP_ENV=prod

# prevent the reinstallation of vendors at every changes in the source code
COPY composer.json composer.lock symfony.lock ./
RUN set -eux; \
Kévin Dunglas's avatar
Kévin Dunglas a validé
	composer install --prefer-dist --no-dev --no-scripts --no-progress --no-suggest; \
	composer clear-cache
Kévin Dunglas's avatar
Kévin Dunglas a validé
# do not use .env files in production
COPY .env ./
RUN composer dump-env prod; \
	rm .env

# copy only specifically what we need
COPY bin bin/
COPY config config/
Kévin Dunglas's avatar
Kévin Dunglas a validé
COPY migrations migrations/
COPY public public/
COPY src src/
RUN set -eux; \
	mkdir -p var/cache var/log; \
	composer dump-autoload --classmap-authoritative --no-dev; \
	composer run-script --no-dev post-install-cmd; \
	chmod +x bin/console; sync
VOLUME /srv/api/var
Ganon's avatar
Ganon a validé
COPY docker/php/docker-healthcheck.sh /usr/local/bin/docker-healthcheck
RUN chmod +x /usr/local/bin/docker-healthcheck

HEALTHCHECK --interval=10s --timeout=3s --retries=3 CMD ["docker-healthcheck"]

COPY docker/php/docker-entrypoint.sh /usr/local/bin/docker-entrypoint
RUN chmod +x /usr/local/bin/docker-entrypoint

ENTRYPOINT ["docker-entrypoint"]
CMD ["php-fpm"]
Teoh Han Hui's avatar
Teoh Han Hui a validé

# "nginx" stage
# depends on the "php" stage above
# The OpenResty distribution of NGINX is only needed for Kubernetes compatiblity (dynamic upstream resolution)
FROM openresty/openresty:${OPENRESTY_VERSION}-alpine AS api_platform_nginx
RUN echo -e "env UPSTREAM;\n$(cat /usr/local/openresty/nginx/conf/nginx.conf)" > /usr/local/openresty/nginx/conf/nginx.conf
COPY docker/nginx/conf.d/default.conf /etc/nginx/conf.d/default.conf

WORKDIR /srv/api/public
COPY --from=api_platform_php /srv/api/public ./
Teoh Han Hui's avatar
Teoh Han Hui a validé

# "varnish" stage
# does not depend on any of the above stages, but placed here to keep everything in one Dockerfile
FROM varnish:${VARNISH_VERSION} AS api_platform_varnish
COPY docker/varnish/conf/default.vcl /etc/varnish/default.vcl

CMD ["varnishd", "-F", "-f", "/etc/varnish/default.vcl", "-p", "http_resp_hdr_len=65536", "-p", "http_resp_size=98304"]