|
| 1 | +ARG PHP_VERSION=7.4.10 |
| 2 | +ARG NGINX_VERSION=1.18 |
| 3 | + |
| 4 | +FROM php:${PHP_VERSION}-fpm-alpine AS app_php |
| 5 | + |
| 6 | +ARG WORKDIR=/app |
| 7 | + |
| 8 | +RUN docker-php-source extract \ |
| 9 | + && apk add --update --virtual .build-deps autoconf g++ make pcre-dev icu-dev openssl-dev libxml2-dev libmcrypt-dev git libpng-dev \ |
| 10 | +# Install pgsql goodness |
| 11 | + && apk add postgresql-dev \ |
| 12 | + && docker-php-ext-install pgsql pdo_pgsql \ |
| 13 | + && apk del postgresql-libs libsasl db \ |
| 14 | +# Instaling pecl modules |
| 15 | + && pecl install apcu \ |
| 16 | +# Enable pecl modules |
| 17 | + && docker-php-ext-enable apcu opcache \ |
| 18 | +# Installing intl |
| 19 | + && apk add icu-libs icu \ |
| 20 | + && docker-php-ext-install intl \ |
| 21 | +# Post run |
| 22 | + && runDeps="$( \ |
| 23 | + scanelf --needed --nobanner --format '%n#p' --recursive /usr/local/lib/php/extensions \ |
| 24 | + | tr ',' '\n' \ |
| 25 | + | sort -u \ |
| 26 | + | awk 'system("[ -e /usr/local/lib/" $1 " ]") == 0 { next } { print "so:" $1 }' \ |
| 27 | + )" \ |
| 28 | + && apk add --no-cache --virtual .app-phpexts-rundeps $runDeps \ |
| 29 | + && pecl clear-cache \ |
| 30 | + && docker-php-source delete \ |
| 31 | + && apk del --purge .build-deps \ |
| 32 | + && rm -rf /tmp/pear \ |
| 33 | + && rm -rf /var/cache/apk/* |
| 34 | + |
| 35 | +COPY --from=composer:1 /usr/bin/composer /usr/local/bin/composer |
| 36 | +COPY docker/php/php.prod.ini $PHP_INI_DIR/conf.d/php.ini |
| 37 | +COPY docker/php/php-cli.prod.ini $PHP_INI_DIR/conf.d/php-cli.ini |
| 38 | + |
| 39 | +RUN mkdir -p ${WORKDIR} |
| 40 | +WORKDIR ${WORKDIR} |
| 41 | + |
| 42 | +# https://getcomposer.org/doc/03-cli.md#composer-allow-superuser |
| 43 | +ENV COMPOSER_ALLOW_SUPERUSER=1 |
| 44 | +RUN set -eux; \ |
| 45 | + composer global require "hirak/prestissimo:^0.3" --prefer-dist --no-progress --no-suggest --classmap-authoritative; \ |
| 46 | + composer clear-cache |
| 47 | + |
| 48 | +# prevent the reinstallation of vendors at every changes in the source code |
| 49 | +COPY composer.json composer.lock symfony.lock ./ |
| 50 | +RUN set -eux; \ |
| 51 | + composer install --prefer-dist --no-autoloader --no-scripts --no-progress --no-suggest; \ |
| 52 | + composer clear-cache |
| 53 | + |
| 54 | +COPY .env ./ |
| 55 | +COPY bin bin/ |
| 56 | +COPY config config/ |
| 57 | +COPY src src/ |
| 58 | +COPY public public/ |
| 59 | + |
| 60 | +RUN set -eux \ |
| 61 | + && mkdir -p var/cache var/log \ |
| 62 | + && composer dump-autoload --classmap-authoritative \ |
| 63 | + && APP_SECRET='' composer run-script post-install-cmd |
| 64 | + |
| 65 | +COPY docker/php/docker-entrypoint.sh /usr/local/bin/docker-entrypoint |
| 66 | +RUN chmod +x /usr/local/bin/docker-entrypoint |
| 67 | + |
| 68 | +RUN chown www-data:www-data -R ${WORKDIR}/var/* ${WORKDIR}/vendor/* |
| 69 | +USER www-data |
| 70 | + |
| 71 | +ENTRYPOINT ["docker-entrypoint"] |
| 72 | +CMD ["php-fpm"] |
| 73 | + |
| 74 | + |
| 75 | +FROM nginx:${NGINX_VERSION}-alpine AS app_nginx |
| 76 | + |
| 77 | +COPY docker/nginx/conf.d/default.conf /etc/nginx/conf.d/ |
| 78 | + |
| 79 | +WORKDIR /app/public |
| 80 | + |
| 81 | +COPY --from=app_php /app/public public/ |
0 commit comments