-
Notifications
You must be signed in to change notification settings - Fork 35
/
Copy pathmateria-app.Dockerfile
108 lines (88 loc) · 5.56 KB
/
materia-app.Dockerfile
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
# =====================================================================================================
# Base stage used for build and final stages
# =====================================================================================================
FROM php:8.1.11-fpm-alpine3.16 AS base_stage
ARG PHP_EXT="bcmath gd pdo_mysql xml zip opcache"
ARG PHP_MEMCACHED_VERSION="v3.1.5"
ARG COMPOSER_VERSION="2.5.4"
ARG COMPOSER_INSTALLER_URL="https://raw.githubusercontent.com/composer/getcomposer.org/be31d0a5e5e835063c29bb45804bd94eefd4cf34/web/installer"
ARG COMPOSER_INSTALLER_SHA="55ce33d7678c5a611085589f1f3ddf8b3c52d662cd01d4ba75c0ee0459970c2200a51f492d557530c71c15d8dba01eae"
# os packages needed for php extensions
ARG BASE_PACKAGES="bash zip libmemcached-dev libxml2-dev zip libzip libzip-dev git freetype libpng libjpeg-turbo linux-headers"
ARG BUILD_PACKAGES="autoconf build-base cyrus-sasl-dev libpng-dev libjpeg-turbo-dev shadow"
ARG PURGE_FILES="/var/lib/apt/lists/* /usr/src/php /usr/include /usr/local/include /usr/share/doc /usr/share/doc-base /var/www/html/php-memcached"
RUN apk add --no-cache $BASE_PACKAGES $BUILD_PACKAGES \
&& usermod -u 1000 www-data && groupmod -g 1000 www-data \
# ======== PHP XDEBUG
&& pecl install xdebug \
&& docker-php-ext-enable xdebug \
&& docker-php-ext-configure gd --with-jpeg=/usr/include \
&& docker-php-ext-install $PHP_EXT \
&& git clone -b $PHP_MEMCACHED_VERSION https://github.com/php-memcached-dev/php-memcached.git \
&& cd php-memcached \
&& phpize \
&& ./configure \
&& make \
&& make install \
&& docker-php-ext-enable $PHP_EXT_ENABLE memcached \
&& apk del $BUILD_PACKAGES \
&& rm -rf $PURGE_FILES
# ======== PHP COMPOSER
RUN php -r "copy('$COMPOSER_INSTALLER_URL', 'composer-setup.php');"
RUN php -r "if (hash_file('sha384', 'composer-setup.php') === '$COMPOSER_INSTALLER_SHA') { echo 'COMPOSER VERIFIED'; } else { echo 'COMPOSER INVALID'; exit(1); } echo PHP_EOL;"
RUN php composer-setup.php --install-dir=/usr/local/bin --filename=composer --version=$COMPOSER_VERSION
# Use the default production configuration
RUN mv "$PHP_INI_DIR/php.ini-production" "$PHP_INI_DIR/php.ini"
# By default the php-fpm image is including access.log in the docker stream
# These logs aren't particularly useful and add considerable bloat to the prod logs that have to be filtered out
# Modify php-fpm.d/docker.conf to point access.log to /dev/null/, which effectively prevents it from being picked up by the log driver
RUN sed -i 's/access.log = .*/access.log = \/dev\/null/' /usr/local/etc/php-fpm.d/docker.conf
# Adds an easily accessible override config for php-fpm's pm.max_children value
# The base image sets this value at 5, and the default value in the override matches that
# If an instance of Materia receives moderate traffic, this value will likely need to be raised
# The file is renamed to zzz-materia.conf to ensure it is loaded last, a zz-docker.conf will already be present in the php-fpm.d directory
#
# If preferred, the configuration can be mounted via volume in your deployment's compose file instead
#
# COPY ./docker/config/php/materia.www.conf /usr/local/etc/php-fpm.d/zzz-materia.conf
WORKDIR /var/www/html
# =====================================================================================================
# composer stage runs composer install
# =====================================================================================================
FROM base_stage as composer_stage
USER www-data
# ======== COPY APP IN
COPY --chown=www-data:www-data ./README.md /var/www/html/README.md
COPY --chown=www-data:www-data ./fuel /var/www/html/fuel
COPY --chown=www-data:www-data ./public /var/www/html/public
COPY --chown=www-data:www-data ./.env /var/www/html/.env
COPY --chown=www-data:www-data ./composer.json /var/www/html/composer.json
COPY --chown=www-data:www-data ./composer.lock /var/www/html/composer.lock
COPY --chown=www-data:www-data ./oil /var/www/html/oil
RUN composer install --no-cache --no-dev --no-progress --no-scripts --prefer-dist --optimize-autoloader
# =====================================================================================================
# Yarn stage build js/css assets
# =====================================================================================================
FROM node:18.13.0-alpine AS yarn_stage
RUN apk add --no-cache git
COPY ./public /build/public
# copy configs into /build. These are required for yarn and webpack
COPY ./package.json /build/package.json
COPY ./babel.config.json /build/babel.config.json
COPY ./webpack.prod.config.js /build/webpack.prod.config.js
COPY ./yarn.lock /build/yarn.lock
# these directories must be hoisted into /build in order for webpack to work on them
COPY ./src /build/src
COPY --from=composer_stage /var/www/html/fuel/packages /build/fuel/packages
RUN mkdir -p /build/fuel/app/config/
# run yarn install and then the build script in the package.json (webpack --config webpack.prod.config.js)
RUN cd build && yarn install --frozen-lockfile --non-interactive --silent --pure-lockfile --force && npm run-script build-for-image
# =====================================================================================================
# final stage creates the final deployable image
# =====================================================================================================
FROM base_stage as FINAL_STAGE
COPY docker/config/php/materia.php.ini $PHP_INI_DIR/conf.d/materia.php.ini
USER www-data
# ======== COPY FINAL APP
COPY --from=composer_stage --chown=www-data:www-data /var/www/html /var/www/html
COPY --from=yarn_stage --chown=www-data:www-data /build/public /var/www/html/public