Install sentry only on x86_64 images (#3)
This commit is contained in:
parent
8bd9a39742
commit
dbb9e8fd83
@ -5,40 +5,40 @@ FROM php:%%PHP_VERSION%%-%%VARIANT%%
|
|||||||
# entrypoint.sh dependencies
|
# entrypoint.sh dependencies
|
||||||
RUN set -ex; \
|
RUN set -ex; \
|
||||||
\
|
\
|
||||||
apk add --no-cache \
|
apk add --no-cache \
|
||||||
bash \
|
bash \
|
||||||
coreutils \
|
coreutils \
|
||||||
rsync \
|
rsync \
|
||||||
; \
|
; \
|
||||||
rm -rf /var/cache/apk/*
|
rm -rf /var/cache/apk/*
|
||||||
|
|
||||||
# Install required PHP extensions
|
# Install required PHP extensions
|
||||||
RUN set -ex; \
|
RUN set -ex; \
|
||||||
\
|
\
|
||||||
apk add --no-cache --virtual .build-deps \
|
apk add --no-cache --virtual .build-deps \
|
||||||
$PHPIZE_DEPS \
|
$PHPIZE_DEPS \
|
||||||
icu-dev \
|
icu-dev \
|
||||||
zlib-dev \
|
zlib-dev \
|
||||||
libzip-dev \
|
libzip-dev \
|
||||||
libxml2-dev \
|
libxml2-dev \
|
||||||
freetype-dev \
|
freetype-dev \
|
||||||
libpng-dev \
|
libpng-dev \
|
||||||
libjpeg-turbo-dev \
|
libjpeg-turbo-dev \
|
||||||
jpeg-dev \
|
jpeg-dev \
|
||||||
gmp-dev \
|
gmp-dev \
|
||||||
libsodium-dev \
|
libsodium-dev \
|
||||||
libmemcached-dev \
|
libmemcached-dev \
|
||||||
; \
|
; \
|
||||||
\
|
\
|
||||||
docker-php-ext-configure intl; \
|
docker-php-ext-configure intl; \
|
||||||
docker-php-ext-configure gd \
|
docker-php-ext-configure gd \
|
||||||
--with-gd \
|
--with-gd \
|
||||||
--with-freetype-dir=/usr/include/ \
|
--with-freetype-dir=/usr/include/ \
|
||||||
--with-jpeg-dir=/usr/include/ \
|
--with-jpeg-dir=/usr/include/ \
|
||||||
--with-png-dir=/usr/include/ \
|
--with-png-dir=/usr/include/ \
|
||||||
; \
|
; \
|
||||||
docker-php-ext-configure gmp; \
|
docker-php-ext-configure gmp; \
|
||||||
docker-php-ext-install -j "$(nproc)" \
|
docker-php-ext-install -j "$(nproc)" \
|
||||||
intl \
|
intl \
|
||||||
zip \
|
zip \
|
||||||
json \
|
json \
|
||||||
@ -52,32 +52,32 @@ RUN set -ex; \
|
|||||||
sodium \
|
sodium \
|
||||||
mbstring \
|
mbstring \
|
||||||
opcache \
|
opcache \
|
||||||
; \
|
; \
|
||||||
# pecl will claim success even if one install fails, so we need to perform each install separately
|
# pecl will claim success even if one install fails, so we need to perform each install separately
|
||||||
pecl install APCu-%%APCU_VERSION%%; \
|
pecl install APCu-%%APCU_VERSION%%; \
|
||||||
pecl install memcached-%%MEMCACHED_VERSION%%; \
|
pecl install memcached-%%MEMCACHED_VERSION%%; \
|
||||||
pecl install redis-%%REDIS_VERSION%%; \
|
pecl install redis-%%REDIS_VERSION%%; \
|
||||||
\
|
\
|
||||||
docker-php-ext-enable \
|
docker-php-ext-enable \
|
||||||
apcu \
|
apcu \
|
||||||
memcached \
|
memcached \
|
||||||
redis \
|
redis \
|
||||||
; \
|
; \
|
||||||
\
|
\
|
||||||
runDeps="$( \
|
runDeps="$( \
|
||||||
scanelf --needed --nobanner --format '%n#p' --recursive /usr/local/lib/php/extensions \
|
scanelf --needed --nobanner --format '%n#p' --recursive /usr/local/lib/php/extensions \
|
||||||
| tr ',' '\n' \
|
| tr ',' '\n' \
|
||||||
| sort -u \
|
| sort -u \
|
||||||
| awk 'system("[ -e /usr/local/lib/" $1 " ]") == 0 { next } { print "so:" $1 }' \
|
| awk 'system("[ -e /usr/local/lib/" $1 " ]") == 0 { next } { print "so:" $1 }' \
|
||||||
)"; \
|
)"; \
|
||||||
apk add --virtual .monica-phpext-rundeps $runDeps; \
|
apk add --virtual .monica-phpext-rundeps $runDeps; \
|
||||||
apk del .build-deps; \
|
apk del .build-deps; \
|
||||||
rm -rf /var/cache/apk/*
|
rm -rf /var/cache/apk/*
|
||||||
|
|
||||||
# Set crontab for schedules
|
# Set crontab for schedules
|
||||||
RUN set -ex; \
|
RUN set -ex; \
|
||||||
\
|
\
|
||||||
rm /var/spool/cron/crontabs/root; \
|
rm /var/spool/cron/crontabs/root; \
|
||||||
echo '*/5 * * * * php /var/www/html/artisan schedule:run -v > /proc/1/fd/1 2> /proc/1/fd/2' > /var/spool/cron/crontabs/www-data
|
echo '*/5 * * * * php /var/www/html/artisan schedule:run -v > /proc/1/fd/1 2> /proc/1/fd/2' > /var/spool/cron/crontabs/www-data
|
||||||
|
|
||||||
# Opcache
|
# Opcache
|
||||||
@ -86,7 +86,7 @@ ENV PHP_OPCACHE_VALIDATE_TIMESTAMPS="0" \
|
|||||||
PHP_OPCACHE_MEMORY_CONSUMPTION="192" \
|
PHP_OPCACHE_MEMORY_CONSUMPTION="192" \
|
||||||
PHP_OPCACHE_MAX_WASTED_PERCENTAGE="10"
|
PHP_OPCACHE_MAX_WASTED_PERCENTAGE="10"
|
||||||
RUN { \
|
RUN { \
|
||||||
echo '[opcache]'; \
|
echo '[opcache]'; \
|
||||||
echo 'opcache.enable=1'; \
|
echo 'opcache.enable=1'; \
|
||||||
echo 'opcache.revalidate_freq=0'; \
|
echo 'opcache.revalidate_freq=0'; \
|
||||||
echo "opcache.validate_timestamps=${PHP_OPCACHE_VALIDATE_TIMESTAMPS}"; \
|
echo "opcache.validate_timestamps=${PHP_OPCACHE_VALIDATE_TIMESTAMPS}"; \
|
||||||
@ -95,38 +95,44 @@ RUN { \
|
|||||||
echo "opcache.max_wasted_percentage=${PHP_OPCACHE_MAX_WASTED_PERCENTAGE}"; \
|
echo "opcache.max_wasted_percentage=${PHP_OPCACHE_MAX_WASTED_PERCENTAGE}"; \
|
||||||
echo 'opcache.interned_strings_buffer=16'; \
|
echo 'opcache.interned_strings_buffer=16'; \
|
||||||
echo 'opcache.fast_shutdown=1'; \
|
echo 'opcache.fast_shutdown=1'; \
|
||||||
} > /usr/local/etc/php/conf.d/opcache-recommended.ini; \
|
} > $PHP_INI_DIR/conf.d/opcache-recommended.ini; \
|
||||||
\
|
\
|
||||||
echo 'apc.enable_cli=1' >> /usr/local/etc/php/conf.d/docker-php-ext-apcu.ini; \
|
echo 'apc.enable_cli=1' >> $PHP_INI_DIR/conf.d/docker-php-ext-apcu.ini; \
|
||||||
\
|
\
|
||||||
echo 'memory_limit=512M' > /usr/local/etc/php/conf.d/memory-limit.ini
|
echo 'memory_limit=512M' > $PHP_INI_DIR/conf.d/memory-limit.ini
|
||||||
|
|
||||||
# Sentry
|
# Sentry
|
||||||
RUN mkdir -p /root/.local/bin; \
|
RUN if [ $(uname -m) = "x86_64" ]; then \
|
||||||
curl -sL https://sentry.io/get-cli/ | INSTALL_DIR=/root/.local/bin bash
|
PLATFORM=$(uname -s); \
|
||||||
|
if [ "$PLATFORM" = "Linux" -o "$PLATFORM" = "Windows" -o "$PLATFORM" = "Darwin" ]; then \
|
||||||
|
mkdir -p /root/.local/bin; \
|
||||||
|
curl -sL https://sentry.io/get-cli/ | INSTALL_DIR=/root/.local/bin bash; \
|
||||||
|
fi \
|
||||||
|
fi
|
||||||
|
|
||||||
VOLUME /var/www/html
|
VOLUME /var/www/html
|
||||||
|
|
||||||
# Define Monica version and expected SHA512 signature
|
# Define Monica version and expected SHA512 signature
|
||||||
ENV MONICA_VERSION %%VERSION%%
|
ENV MONICA_VERSION %%VERSION%%
|
||||||
ENV MONICA_SHA512 %%SHA512%%
|
ENV MONICA_SHA512 %%SHA512%%
|
||||||
|
ENV MONICA_SRC /usr/src/monica
|
||||||
|
|
||||||
RUN set -ex; \
|
RUN set -ex; \
|
||||||
apk add --no-cache --virtual .fetch-deps \
|
apk add --no-cache --virtual .fetch-deps \
|
||||||
bzip2 \
|
bzip2 \
|
||||||
; \
|
; \
|
||||||
\
|
\
|
||||||
curl -fsSL -o monica.tar.bz2 "https://github.com/monicahq/monica/releases/download/${MONICA_VERSION}/monica-${MONICA_VERSION}.tar.bz2"; \
|
curl -fsSL -o monica.tar.bz2 "https://github.com/monicahq/monica/releases/download/${MONICA_VERSION}/monica-${MONICA_VERSION}.tar.bz2"; \
|
||||||
echo "$MONICA_SHA512 *monica.tar.bz2" | sha512sum -c -; \
|
echo "$MONICA_SHA512 *monica.tar.bz2" | sha512sum -c -; \
|
||||||
\
|
\
|
||||||
mkdir /usr/src/monica; \
|
mkdir $MONICA_SRC; \
|
||||||
tar -xf monica.tar.bz2 -C /usr/src/monica --strip-components=1; \
|
tar -xf monica.tar.bz2 -C $MONICA_SRC --strip-components=1; \
|
||||||
rm monica.tar.bz2; \
|
rm monica.tar.bz2; \
|
||||||
\
|
\
|
||||||
cp /usr/src/monica/.env.example /usr/src/monica/.env; \
|
cp $MONICA_SRC/.env.example $MONICA_SRC/.env; \
|
||||||
chown -R www-data:www-data /usr/src/monica; \
|
chown -R www-data:www-data $MONICA_SRC; \
|
||||||
\
|
\
|
||||||
apk del .fetch-deps; \
|
apk del .fetch-deps; \
|
||||||
rm -rf /var/cache/apk/*
|
rm -rf /var/cache/apk/*
|
||||||
|
|
||||||
COPY upgrade.exclude \
|
COPY upgrade.exclude \
|
||||||
|
|||||||
@ -16,11 +16,11 @@ RUN set -ex; \
|
|||||||
|
|
||||||
# Install required PHP extensions
|
# Install required PHP extensions
|
||||||
RUN set -ex; \
|
RUN set -ex; \
|
||||||
\
|
\
|
||||||
savedAptMark="$(apt-mark showmanual)"; \
|
savedAptMark="$(apt-mark showmanual)"; \
|
||||||
\
|
\
|
||||||
apt-get update; \
|
apt-get update; \
|
||||||
apt-get install -y --no-install-recommends \
|
apt-get install -y --no-install-recommends \
|
||||||
libicu-dev \
|
libicu-dev \
|
||||||
zlib1g-dev \
|
zlib1g-dev \
|
||||||
libzip-dev \
|
libzip-dev \
|
||||||
@ -31,13 +31,13 @@ RUN set -ex; \
|
|||||||
libgmp-dev \
|
libgmp-dev \
|
||||||
libsodium-dev \
|
libsodium-dev \
|
||||||
libmemcached-dev \
|
libmemcached-dev \
|
||||||
; \
|
; \
|
||||||
\
|
\
|
||||||
debMultiarch="$(dpkg-architecture --query DEB_BUILD_MULTIARCH)"; \
|
debMultiarch="$(dpkg-architecture --query DEB_BUILD_MULTIARCH)"; \
|
||||||
if [ ! -e /usr/include/gmp.h ]; then ln -s /usr/include/$debMultiarch/gmp.h /usr/include/gmp.h; fi;\
|
if [ ! -e /usr/include/gmp.h ]; then ln -s /usr/include/$debMultiarch/gmp.h /usr/include/gmp.h; fi;\
|
||||||
docker-php-ext-configure intl; \
|
docker-php-ext-configure intl; \
|
||||||
docker-php-ext-configure gd --with-freetype-dir=/usr/include/ --with-jpeg-dir=/usr/include/ --with-png-dir=/usr/include/; \
|
docker-php-ext-configure gd --with-freetype-dir=/usr/include/ --with-jpeg-dir=/usr/include/ --with-png-dir=/usr/include/; \
|
||||||
docker-php-ext-configure gmp --with-gmp="/usr/include/$debMultiarch"; \
|
docker-php-ext-configure gmp --with-gmp="/usr/include/$debMultiarch"; \
|
||||||
docker-php-ext-install -j$(nproc) \
|
docker-php-ext-install -j$(nproc) \
|
||||||
intl \
|
intl \
|
||||||
zip \
|
zip \
|
||||||
@ -52,12 +52,12 @@ RUN set -ex; \
|
|||||||
sodium \
|
sodium \
|
||||||
mbstring \
|
mbstring \
|
||||||
opcache \
|
opcache \
|
||||||
; \
|
; \
|
||||||
\
|
\
|
||||||
# pecl will claim success even if one install fails, so we need to perform each install separately
|
# pecl will claim success even if one install fails, so we need to perform each install separately
|
||||||
pecl install APCu-%%APCU_VERSION%%; \
|
pecl install APCu-%%APCU_VERSION%%; \
|
||||||
pecl install memcached-%%MEMCACHED_VERSION%%; \
|
pecl install memcached-%%MEMCACHED_VERSION%%; \
|
||||||
pecl install redis-%%REDIS_VERSION%%; \
|
pecl install redis-%%REDIS_VERSION%%; \
|
||||||
\
|
\
|
||||||
docker-php-ext-enable \
|
docker-php-ext-enable \
|
||||||
apcu \
|
apcu \
|
||||||
@ -66,27 +66,27 @@ RUN set -ex; \
|
|||||||
; \
|
; \
|
||||||
\
|
\
|
||||||
# reset apt-mark's "manual" list so that "purge --auto-remove" will remove all build dependencies
|
# reset apt-mark's "manual" list so that "purge --auto-remove" will remove all build dependencies
|
||||||
apt-mark auto '.*' > /dev/null; \
|
apt-mark auto '.*' > /dev/null; \
|
||||||
apt-mark manual $savedAptMark; \
|
apt-mark manual $savedAptMark; \
|
||||||
ldd "$(php -r 'echo ini_get("extension_dir");')"/*.so \
|
ldd "$(php -r 'echo ini_get("extension_dir");')"/*.so \
|
||||||
| awk '/=>/ { print $3 }' \
|
| awk '/=>/ { print $3 }' \
|
||||||
| sort -u \
|
| sort -u \
|
||||||
| xargs -r dpkg-query -S \
|
| xargs -r dpkg-query -S \
|
||||||
| cut -d: -f1 \
|
| cut -d: -f1 \
|
||||||
| sort -u \
|
| sort -u \
|
||||||
| xargs -rt apt-mark manual; \
|
| xargs -rt apt-mark manual; \
|
||||||
\
|
\
|
||||||
apt-get purge -y --auto-remove -o APT::AutoRemove::RecommendsImportant=false; \
|
apt-get purge -y --auto-remove -o APT::AutoRemove::RecommendsImportant=false; \
|
||||||
rm -rf /var/lib/apt/lists/*; \
|
rm -rf /var/lib/apt/lists/*; \
|
||||||
\
|
\
|
||||||
if command -v a2enmod; then \
|
if command -v a2enmod; then \
|
||||||
a2enmod rewrite; \
|
a2enmod rewrite; \
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Set crontab for schedules
|
# Set crontab for schedules
|
||||||
RUN set -ex; \
|
RUN set -ex; \
|
||||||
\
|
\
|
||||||
mkdir -p /var/spool/cron/crontabs; \
|
mkdir -p /var/spool/cron/crontabs; \
|
||||||
echo '*/5 * * * * php /var/www/html/artisan schedule:run -v > /proc/1/fd/1 2> /proc/1/fd/2' > /var/spool/cron/crontabs/www-data
|
echo '*/5 * * * * php /var/www/html/artisan schedule:run -v > /proc/1/fd/1 2> /proc/1/fd/2' > /var/spool/cron/crontabs/www-data
|
||||||
|
|
||||||
# Opcache
|
# Opcache
|
||||||
@ -95,7 +95,7 @@ ENV PHP_OPCACHE_VALIDATE_TIMESTAMPS="0" \
|
|||||||
PHP_OPCACHE_MEMORY_CONSUMPTION="192" \
|
PHP_OPCACHE_MEMORY_CONSUMPTION="192" \
|
||||||
PHP_OPCACHE_MAX_WASTED_PERCENTAGE="10"
|
PHP_OPCACHE_MAX_WASTED_PERCENTAGE="10"
|
||||||
RUN { \
|
RUN { \
|
||||||
echo '[opcache]'; \
|
echo '[opcache]'; \
|
||||||
echo 'opcache.enable=1'; \
|
echo 'opcache.enable=1'; \
|
||||||
echo 'opcache.revalidate_freq=0'; \
|
echo 'opcache.revalidate_freq=0'; \
|
||||||
echo "opcache.validate_timestamps=${PHP_OPCACHE_VALIDATE_TIMESTAMPS}"; \
|
echo "opcache.validate_timestamps=${PHP_OPCACHE_VALIDATE_TIMESTAMPS}"; \
|
||||||
@ -104,34 +104,40 @@ RUN { \
|
|||||||
echo "opcache.max_wasted_percentage=${PHP_OPCACHE_MAX_WASTED_PERCENTAGE}"; \
|
echo "opcache.max_wasted_percentage=${PHP_OPCACHE_MAX_WASTED_PERCENTAGE}"; \
|
||||||
echo 'opcache.interned_strings_buffer=16'; \
|
echo 'opcache.interned_strings_buffer=16'; \
|
||||||
echo 'opcache.fast_shutdown=1'; \
|
echo 'opcache.fast_shutdown=1'; \
|
||||||
} > /usr/local/etc/php/conf.d/opcache-recommended.ini; \
|
} > $PHP_INI_DIR/conf.d/opcache-recommended.ini; \
|
||||||
\
|
\
|
||||||
echo 'apc.enable_cli=1' >> /usr/local/etc/php/conf.d/docker-php-ext-apcu.ini; \
|
echo 'apc.enable_cli=1' >> $PHP_INI_DIR/conf.d/docker-php-ext-apcu.ini; \
|
||||||
\
|
\
|
||||||
echo 'memory_limit=512M' > /usr/local/etc/php/conf.d/memory-limit.ini
|
echo 'memory_limit=512M' > $PHP_INI_DIR/conf.d/memory-limit.ini
|
||||||
|
|
||||||
# Sentry
|
# Sentry
|
||||||
RUN mkdir -p /root/.local/bin; \
|
RUN if [ $(uname -m) = "x86_64" ]; then \
|
||||||
curl -sL https://sentry.io/get-cli/ | INSTALL_DIR=/root/.local/bin bash
|
PLATFORM=$(uname -s); \
|
||||||
|
if [ "$PLATFORM" = "Linux" -o "$PLATFORM" = "Windows" -o "$PLATFORM" = "Darwin" ]; then \
|
||||||
|
mkdir -p /root/.local/bin; \
|
||||||
|
curl -sL https://sentry.io/get-cli/ | INSTALL_DIR=/root/.local/bin bash; \
|
||||||
|
fi \
|
||||||
|
fi
|
||||||
|
|
||||||
VOLUME /var/www/html
|
VOLUME /var/www/html
|
||||||
|
|
||||||
# Define Monica version and expected SHA512 signature
|
# Define Monica version and expected SHA512 signature
|
||||||
ENV MONICA_VERSION %%VERSION%%
|
ENV MONICA_VERSION %%VERSION%%
|
||||||
ENV MONICA_SHA512 %%SHA512%%
|
ENV MONICA_SHA512 %%SHA512%%
|
||||||
|
ENV MONICA_SRC /usr/src/monica
|
||||||
|
|
||||||
%%APACHE_DOCUMENT%%
|
%%APACHE_DOCUMENT%%
|
||||||
|
|
||||||
RUN set -eu; \
|
RUN set -eu; \
|
||||||
curl -fsSL -o monica.tar.bz2 "https://github.com/monicahq/monica/releases/download/${MONICA_VERSION}/monica-${MONICA_VERSION}.tar.bz2"; \
|
curl -fsSL -o monica.tar.bz2 "https://github.com/monicahq/monica/releases/download/${MONICA_VERSION}/monica-${MONICA_VERSION}.tar.bz2"; \
|
||||||
echo "$MONICA_SHA512 *monica.tar.bz2" | sha512sum -c -; \
|
echo "$MONICA_SHA512 *monica.tar.bz2" | sha512sum -c -; \
|
||||||
\
|
\
|
||||||
mkdir /usr/src/monica; \
|
mkdir $MONICA_SRC; \
|
||||||
tar -xf monica.tar.bz2 -C /usr/src/monica --strip-components=1; \
|
tar -xf monica.tar.bz2 -C $MONICA_SRC --strip-components=1; \
|
||||||
rm monica.tar.bz2; \
|
rm monica.tar.bz2; \
|
||||||
\
|
\
|
||||||
cp /usr/src/monica/.env.example /usr/src/monica/.env; \
|
cp $MONICA_SRC/.env.example $MONICA_SRC/.env; \
|
||||||
chown -R www-data:www-data /usr/src/monica
|
chown -R www-data:www-data $MONICA_SRC
|
||||||
|
|
||||||
COPY upgrade.exclude \
|
COPY upgrade.exclude \
|
||||||
/usr/local/share/
|
/usr/local/share/
|
||||||
|
|||||||
@ -22,11 +22,11 @@ RUN set -ex; \
|
|||||||
|
|
||||||
# Install required PHP extensions
|
# Install required PHP extensions
|
||||||
RUN set -ex; \
|
RUN set -ex; \
|
||||||
\
|
\
|
||||||
savedAptMark="$(apt-mark showmanual)"; \
|
savedAptMark="$(apt-mark showmanual)"; \
|
||||||
\
|
\
|
||||||
apt-get update; \
|
apt-get update; \
|
||||||
apt-get install -y --no-install-recommends \
|
apt-get install -y --no-install-recommends \
|
||||||
libicu-dev \
|
libicu-dev \
|
||||||
zlib1g-dev \
|
zlib1g-dev \
|
||||||
libzip-dev \
|
libzip-dev \
|
||||||
@ -37,13 +37,13 @@ RUN set -ex; \
|
|||||||
libgmp-dev \
|
libgmp-dev \
|
||||||
libsodium-dev \
|
libsodium-dev \
|
||||||
libmemcached-dev \
|
libmemcached-dev \
|
||||||
; \
|
; \
|
||||||
\
|
\
|
||||||
debMultiarch="$(dpkg-architecture --query DEB_BUILD_MULTIARCH)"; \
|
debMultiarch="$(dpkg-architecture --query DEB_BUILD_MULTIARCH)"; \
|
||||||
if [ ! -e /usr/include/gmp.h ]; then ln -s /usr/include/$debMultiarch/gmp.h /usr/include/gmp.h; fi;\
|
if [ ! -e /usr/include/gmp.h ]; then ln -s /usr/include/$debMultiarch/gmp.h /usr/include/gmp.h; fi;\
|
||||||
docker-php-ext-configure intl; \
|
docker-php-ext-configure intl; \
|
||||||
docker-php-ext-configure gd --with-freetype-dir=/usr/include/ --with-jpeg-dir=/usr/include/ --with-png-dir=/usr/include/; \
|
docker-php-ext-configure gd --with-freetype-dir=/usr/include/ --with-jpeg-dir=/usr/include/ --with-png-dir=/usr/include/; \
|
||||||
docker-php-ext-configure gmp --with-gmp="/usr/include/$debMultiarch"; \
|
docker-php-ext-configure gmp --with-gmp="/usr/include/$debMultiarch"; \
|
||||||
docker-php-ext-install -j$(nproc) \
|
docker-php-ext-install -j$(nproc) \
|
||||||
intl \
|
intl \
|
||||||
zip \
|
zip \
|
||||||
@ -58,12 +58,12 @@ RUN set -ex; \
|
|||||||
sodium \
|
sodium \
|
||||||
mbstring \
|
mbstring \
|
||||||
opcache \
|
opcache \
|
||||||
; \
|
; \
|
||||||
\
|
\
|
||||||
# pecl will claim success even if one install fails, so we need to perform each install separately
|
# pecl will claim success even if one install fails, so we need to perform each install separately
|
||||||
pecl install APCu-5.1.18; \
|
pecl install APCu-5.1.18; \
|
||||||
pecl install memcached-3.1.5; \
|
pecl install memcached-3.1.5; \
|
||||||
pecl install redis-5.1.1; \
|
pecl install redis-5.1.1; \
|
||||||
\
|
\
|
||||||
docker-php-ext-enable \
|
docker-php-ext-enable \
|
||||||
apcu \
|
apcu \
|
||||||
@ -72,27 +72,27 @@ RUN set -ex; \
|
|||||||
; \
|
; \
|
||||||
\
|
\
|
||||||
# reset apt-mark's "manual" list so that "purge --auto-remove" will remove all build dependencies
|
# reset apt-mark's "manual" list so that "purge --auto-remove" will remove all build dependencies
|
||||||
apt-mark auto '.*' > /dev/null; \
|
apt-mark auto '.*' > /dev/null; \
|
||||||
apt-mark manual $savedAptMark; \
|
apt-mark manual $savedAptMark; \
|
||||||
ldd "$(php -r 'echo ini_get("extension_dir");')"/*.so \
|
ldd "$(php -r 'echo ini_get("extension_dir");')"/*.so \
|
||||||
| awk '/=>/ { print $3 }' \
|
| awk '/=>/ { print $3 }' \
|
||||||
| sort -u \
|
| sort -u \
|
||||||
| xargs -r dpkg-query -S \
|
| xargs -r dpkg-query -S \
|
||||||
| cut -d: -f1 \
|
| cut -d: -f1 \
|
||||||
| sort -u \
|
| sort -u \
|
||||||
| xargs -rt apt-mark manual; \
|
| xargs -rt apt-mark manual; \
|
||||||
\
|
\
|
||||||
apt-get purge -y --auto-remove -o APT::AutoRemove::RecommendsImportant=false; \
|
apt-get purge -y --auto-remove -o APT::AutoRemove::RecommendsImportant=false; \
|
||||||
rm -rf /var/lib/apt/lists/*; \
|
rm -rf /var/lib/apt/lists/*; \
|
||||||
\
|
\
|
||||||
if command -v a2enmod; then \
|
if command -v a2enmod; then \
|
||||||
a2enmod rewrite; \
|
a2enmod rewrite; \
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Set crontab for schedules
|
# Set crontab for schedules
|
||||||
RUN set -ex; \
|
RUN set -ex; \
|
||||||
\
|
\
|
||||||
mkdir -p /var/spool/cron/crontabs; \
|
mkdir -p /var/spool/cron/crontabs; \
|
||||||
echo '*/5 * * * * php /var/www/html/artisan schedule:run -v > /proc/1/fd/1 2> /proc/1/fd/2' > /var/spool/cron/crontabs/www-data
|
echo '*/5 * * * * php /var/www/html/artisan schedule:run -v > /proc/1/fd/1 2> /proc/1/fd/2' > /var/spool/cron/crontabs/www-data
|
||||||
|
|
||||||
# Opcache
|
# Opcache
|
||||||
@ -101,7 +101,7 @@ ENV PHP_OPCACHE_VALIDATE_TIMESTAMPS="0" \
|
|||||||
PHP_OPCACHE_MEMORY_CONSUMPTION="192" \
|
PHP_OPCACHE_MEMORY_CONSUMPTION="192" \
|
||||||
PHP_OPCACHE_MAX_WASTED_PERCENTAGE="10"
|
PHP_OPCACHE_MAX_WASTED_PERCENTAGE="10"
|
||||||
RUN { \
|
RUN { \
|
||||||
echo '[opcache]'; \
|
echo '[opcache]'; \
|
||||||
echo 'opcache.enable=1'; \
|
echo 'opcache.enable=1'; \
|
||||||
echo 'opcache.revalidate_freq=0'; \
|
echo 'opcache.revalidate_freq=0'; \
|
||||||
echo "opcache.validate_timestamps=${PHP_OPCACHE_VALIDATE_TIMESTAMPS}"; \
|
echo "opcache.validate_timestamps=${PHP_OPCACHE_VALIDATE_TIMESTAMPS}"; \
|
||||||
@ -110,36 +110,42 @@ RUN { \
|
|||||||
echo "opcache.max_wasted_percentage=${PHP_OPCACHE_MAX_WASTED_PERCENTAGE}"; \
|
echo "opcache.max_wasted_percentage=${PHP_OPCACHE_MAX_WASTED_PERCENTAGE}"; \
|
||||||
echo 'opcache.interned_strings_buffer=16'; \
|
echo 'opcache.interned_strings_buffer=16'; \
|
||||||
echo 'opcache.fast_shutdown=1'; \
|
echo 'opcache.fast_shutdown=1'; \
|
||||||
} > /usr/local/etc/php/conf.d/opcache-recommended.ini; \
|
} > $PHP_INI_DIR/conf.d/opcache-recommended.ini; \
|
||||||
\
|
\
|
||||||
echo 'apc.enable_cli=1' >> /usr/local/etc/php/conf.d/docker-php-ext-apcu.ini; \
|
echo 'apc.enable_cli=1' >> $PHP_INI_DIR/conf.d/docker-php-ext-apcu.ini; \
|
||||||
\
|
\
|
||||||
echo 'memory_limit=512M' > /usr/local/etc/php/conf.d/memory-limit.ini
|
echo 'memory_limit=512M' > $PHP_INI_DIR/conf.d/memory-limit.ini
|
||||||
|
|
||||||
# Sentry
|
# Sentry
|
||||||
RUN mkdir -p /root/.local/bin; \
|
RUN if [ $(uname -m) = "x86_64" ]; then \
|
||||||
curl -sL https://sentry.io/get-cli/ | INSTALL_DIR=/root/.local/bin bash
|
PLATFORM=$(uname -s); \
|
||||||
|
if [ "$PLATFORM" = "Linux" -o "$PLATFORM" = "Windows" -o "$PLATFORM" = "Darwin" ]; then \
|
||||||
|
mkdir -p /root/.local/bin; \
|
||||||
|
curl -sL https://sentry.io/get-cli/ | INSTALL_DIR=/root/.local/bin bash; \
|
||||||
|
fi \
|
||||||
|
fi
|
||||||
|
|
||||||
VOLUME /var/www/html
|
VOLUME /var/www/html
|
||||||
|
|
||||||
# Define Monica version and expected SHA512 signature
|
# Define Monica version and expected SHA512 signature
|
||||||
ENV MONICA_VERSION v2.16.0
|
ENV MONICA_VERSION v2.16.0
|
||||||
ENV MONICA_SHA512 f2d1a434b5615bcd100388066854dfd36c81f403e817f45a21d4c04ec9ee022339c25334913586a51e763928d17d8b3fa79b6bf1883cac6fffe1aabfbd14ae3c
|
ENV MONICA_SHA512 f2d1a434b5615bcd100388066854dfd36c81f403e817f45a21d4c04ec9ee022339c25334913586a51e763928d17d8b3fa79b6bf1883cac6fffe1aabfbd14ae3c
|
||||||
|
ENV MONICA_SRC /usr/src/monica
|
||||||
|
|
||||||
ENV APACHE_DOCUMENT_ROOT /var/www/html/public
|
ENV APACHE_DOCUMENT_ROOT /var/www/html/public
|
||||||
RUN set -eu; sed -ri -e "s!/var/www/html!${APACHE_DOCUMENT_ROOT}!g" /etc/apache2/sites-available/*.conf; \
|
RUN set -eu; sed -ri -e "s!/var/www/html!${APACHE_DOCUMENT_ROOT}!g" /etc/apache2/sites-available/*.conf; \
|
||||||
sed -ri -e "s!/var/www/!${APACHE_DOCUMENT_ROOT}!g" /etc/apache2/apache2.conf /etc/apache2/conf-available/*.conf
|
sed -ri -e "s!/var/www/!${APACHE_DOCUMENT_ROOT}!g" /etc/apache2/apache2.conf /etc/apache2/conf-available/*.conf
|
||||||
|
|
||||||
RUN set -eu; \
|
RUN set -eu; \
|
||||||
curl -fsSL -o monica.tar.bz2 "https://github.com/monicahq/monica/releases/download/${MONICA_VERSION}/monica-${MONICA_VERSION}.tar.bz2"; \
|
curl -fsSL -o monica.tar.bz2 "https://github.com/monicahq/monica/releases/download/${MONICA_VERSION}/monica-${MONICA_VERSION}.tar.bz2"; \
|
||||||
echo "$MONICA_SHA512 *monica.tar.bz2" | sha512sum -c -; \
|
echo "$MONICA_SHA512 *monica.tar.bz2" | sha512sum -c -; \
|
||||||
\
|
\
|
||||||
mkdir /usr/src/monica; \
|
mkdir $MONICA_SRC; \
|
||||||
tar -xf monica.tar.bz2 -C /usr/src/monica --strip-components=1; \
|
tar -xf monica.tar.bz2 -C $MONICA_SRC --strip-components=1; \
|
||||||
rm monica.tar.bz2; \
|
rm monica.tar.bz2; \
|
||||||
\
|
\
|
||||||
cp /usr/src/monica/.env.example /usr/src/monica/.env; \
|
cp $MONICA_SRC/.env.example $MONICA_SRC/.env; \
|
||||||
chown -R www-data:www-data /usr/src/monica
|
chown -R www-data:www-data $MONICA_SRC
|
||||||
|
|
||||||
COPY upgrade.exclude \
|
COPY upgrade.exclude \
|
||||||
/usr/local/share/
|
/usr/local/share/
|
||||||
|
|||||||
@ -11,40 +11,40 @@ LABEL maintainer="Alexis Saettler <alexis@saettler.org> (@asbiin)" \
|
|||||||
# entrypoint.sh dependencies
|
# entrypoint.sh dependencies
|
||||||
RUN set -ex; \
|
RUN set -ex; \
|
||||||
\
|
\
|
||||||
apk add --no-cache \
|
apk add --no-cache \
|
||||||
bash \
|
bash \
|
||||||
coreutils \
|
coreutils \
|
||||||
rsync \
|
rsync \
|
||||||
; \
|
; \
|
||||||
rm -rf /var/cache/apk/*
|
rm -rf /var/cache/apk/*
|
||||||
|
|
||||||
# Install required PHP extensions
|
# Install required PHP extensions
|
||||||
RUN set -ex; \
|
RUN set -ex; \
|
||||||
\
|
\
|
||||||
apk add --no-cache --virtual .build-deps \
|
apk add --no-cache --virtual .build-deps \
|
||||||
$PHPIZE_DEPS \
|
$PHPIZE_DEPS \
|
||||||
icu-dev \
|
icu-dev \
|
||||||
zlib-dev \
|
zlib-dev \
|
||||||
libzip-dev \
|
libzip-dev \
|
||||||
libxml2-dev \
|
libxml2-dev \
|
||||||
freetype-dev \
|
freetype-dev \
|
||||||
libpng-dev \
|
libpng-dev \
|
||||||
libjpeg-turbo-dev \
|
libjpeg-turbo-dev \
|
||||||
jpeg-dev \
|
jpeg-dev \
|
||||||
gmp-dev \
|
gmp-dev \
|
||||||
libsodium-dev \
|
libsodium-dev \
|
||||||
libmemcached-dev \
|
libmemcached-dev \
|
||||||
; \
|
; \
|
||||||
\
|
\
|
||||||
docker-php-ext-configure intl; \
|
docker-php-ext-configure intl; \
|
||||||
docker-php-ext-configure gd \
|
docker-php-ext-configure gd \
|
||||||
--with-gd \
|
--with-gd \
|
||||||
--with-freetype-dir=/usr/include/ \
|
--with-freetype-dir=/usr/include/ \
|
||||||
--with-jpeg-dir=/usr/include/ \
|
--with-jpeg-dir=/usr/include/ \
|
||||||
--with-png-dir=/usr/include/ \
|
--with-png-dir=/usr/include/ \
|
||||||
; \
|
; \
|
||||||
docker-php-ext-configure gmp; \
|
docker-php-ext-configure gmp; \
|
||||||
docker-php-ext-install -j "$(nproc)" \
|
docker-php-ext-install -j "$(nproc)" \
|
||||||
intl \
|
intl \
|
||||||
zip \
|
zip \
|
||||||
json \
|
json \
|
||||||
@ -58,32 +58,32 @@ RUN set -ex; \
|
|||||||
sodium \
|
sodium \
|
||||||
mbstring \
|
mbstring \
|
||||||
opcache \
|
opcache \
|
||||||
; \
|
; \
|
||||||
# pecl will claim success even if one install fails, so we need to perform each install separately
|
# pecl will claim success even if one install fails, so we need to perform each install separately
|
||||||
pecl install APCu-5.1.18; \
|
pecl install APCu-5.1.18; \
|
||||||
pecl install memcached-3.1.5; \
|
pecl install memcached-3.1.5; \
|
||||||
pecl install redis-5.1.1; \
|
pecl install redis-5.1.1; \
|
||||||
\
|
\
|
||||||
docker-php-ext-enable \
|
docker-php-ext-enable \
|
||||||
apcu \
|
apcu \
|
||||||
memcached \
|
memcached \
|
||||||
redis \
|
redis \
|
||||||
; \
|
; \
|
||||||
\
|
\
|
||||||
runDeps="$( \
|
runDeps="$( \
|
||||||
scanelf --needed --nobanner --format '%n#p' --recursive /usr/local/lib/php/extensions \
|
scanelf --needed --nobanner --format '%n#p' --recursive /usr/local/lib/php/extensions \
|
||||||
| tr ',' '\n' \
|
| tr ',' '\n' \
|
||||||
| sort -u \
|
| sort -u \
|
||||||
| awk 'system("[ -e /usr/local/lib/" $1 " ]") == 0 { next } { print "so:" $1 }' \
|
| awk 'system("[ -e /usr/local/lib/" $1 " ]") == 0 { next } { print "so:" $1 }' \
|
||||||
)"; \
|
)"; \
|
||||||
apk add --virtual .monica-phpext-rundeps $runDeps; \
|
apk add --virtual .monica-phpext-rundeps $runDeps; \
|
||||||
apk del .build-deps; \
|
apk del .build-deps; \
|
||||||
rm -rf /var/cache/apk/*
|
rm -rf /var/cache/apk/*
|
||||||
|
|
||||||
# Set crontab for schedules
|
# Set crontab for schedules
|
||||||
RUN set -ex; \
|
RUN set -ex; \
|
||||||
\
|
\
|
||||||
rm /var/spool/cron/crontabs/root; \
|
rm /var/spool/cron/crontabs/root; \
|
||||||
echo '*/5 * * * * php /var/www/html/artisan schedule:run -v > /proc/1/fd/1 2> /proc/1/fd/2' > /var/spool/cron/crontabs/www-data
|
echo '*/5 * * * * php /var/www/html/artisan schedule:run -v > /proc/1/fd/1 2> /proc/1/fd/2' > /var/spool/cron/crontabs/www-data
|
||||||
|
|
||||||
# Opcache
|
# Opcache
|
||||||
@ -92,7 +92,7 @@ ENV PHP_OPCACHE_VALIDATE_TIMESTAMPS="0" \
|
|||||||
PHP_OPCACHE_MEMORY_CONSUMPTION="192" \
|
PHP_OPCACHE_MEMORY_CONSUMPTION="192" \
|
||||||
PHP_OPCACHE_MAX_WASTED_PERCENTAGE="10"
|
PHP_OPCACHE_MAX_WASTED_PERCENTAGE="10"
|
||||||
RUN { \
|
RUN { \
|
||||||
echo '[opcache]'; \
|
echo '[opcache]'; \
|
||||||
echo 'opcache.enable=1'; \
|
echo 'opcache.enable=1'; \
|
||||||
echo 'opcache.revalidate_freq=0'; \
|
echo 'opcache.revalidate_freq=0'; \
|
||||||
echo "opcache.validate_timestamps=${PHP_OPCACHE_VALIDATE_TIMESTAMPS}"; \
|
echo "opcache.validate_timestamps=${PHP_OPCACHE_VALIDATE_TIMESTAMPS}"; \
|
||||||
@ -101,38 +101,44 @@ RUN { \
|
|||||||
echo "opcache.max_wasted_percentage=${PHP_OPCACHE_MAX_WASTED_PERCENTAGE}"; \
|
echo "opcache.max_wasted_percentage=${PHP_OPCACHE_MAX_WASTED_PERCENTAGE}"; \
|
||||||
echo 'opcache.interned_strings_buffer=16'; \
|
echo 'opcache.interned_strings_buffer=16'; \
|
||||||
echo 'opcache.fast_shutdown=1'; \
|
echo 'opcache.fast_shutdown=1'; \
|
||||||
} > /usr/local/etc/php/conf.d/opcache-recommended.ini; \
|
} > $PHP_INI_DIR/conf.d/opcache-recommended.ini; \
|
||||||
\
|
\
|
||||||
echo 'apc.enable_cli=1' >> /usr/local/etc/php/conf.d/docker-php-ext-apcu.ini; \
|
echo 'apc.enable_cli=1' >> $PHP_INI_DIR/conf.d/docker-php-ext-apcu.ini; \
|
||||||
\
|
\
|
||||||
echo 'memory_limit=512M' > /usr/local/etc/php/conf.d/memory-limit.ini
|
echo 'memory_limit=512M' > $PHP_INI_DIR/conf.d/memory-limit.ini
|
||||||
|
|
||||||
# Sentry
|
# Sentry
|
||||||
RUN mkdir -p /root/.local/bin; \
|
RUN if [ $(uname -m) = "x86_64" ]; then \
|
||||||
curl -sL https://sentry.io/get-cli/ | INSTALL_DIR=/root/.local/bin bash
|
PLATFORM=$(uname -s); \
|
||||||
|
if [ "$PLATFORM" = "Linux" -o "$PLATFORM" = "Windows" -o "$PLATFORM" = "Darwin" ]; then \
|
||||||
|
mkdir -p /root/.local/bin; \
|
||||||
|
curl -sL https://sentry.io/get-cli/ | INSTALL_DIR=/root/.local/bin bash; \
|
||||||
|
fi \
|
||||||
|
fi
|
||||||
|
|
||||||
VOLUME /var/www/html
|
VOLUME /var/www/html
|
||||||
|
|
||||||
# Define Monica version and expected SHA512 signature
|
# Define Monica version and expected SHA512 signature
|
||||||
ENV MONICA_VERSION v2.16.0
|
ENV MONICA_VERSION v2.16.0
|
||||||
ENV MONICA_SHA512 f2d1a434b5615bcd100388066854dfd36c81f403e817f45a21d4c04ec9ee022339c25334913586a51e763928d17d8b3fa79b6bf1883cac6fffe1aabfbd14ae3c
|
ENV MONICA_SHA512 f2d1a434b5615bcd100388066854dfd36c81f403e817f45a21d4c04ec9ee022339c25334913586a51e763928d17d8b3fa79b6bf1883cac6fffe1aabfbd14ae3c
|
||||||
|
ENV MONICA_SRC /usr/src/monica
|
||||||
|
|
||||||
RUN set -ex; \
|
RUN set -ex; \
|
||||||
apk add --no-cache --virtual .fetch-deps \
|
apk add --no-cache --virtual .fetch-deps \
|
||||||
bzip2 \
|
bzip2 \
|
||||||
; \
|
; \
|
||||||
\
|
\
|
||||||
curl -fsSL -o monica.tar.bz2 "https://github.com/monicahq/monica/releases/download/${MONICA_VERSION}/monica-${MONICA_VERSION}.tar.bz2"; \
|
curl -fsSL -o monica.tar.bz2 "https://github.com/monicahq/monica/releases/download/${MONICA_VERSION}/monica-${MONICA_VERSION}.tar.bz2"; \
|
||||||
echo "$MONICA_SHA512 *monica.tar.bz2" | sha512sum -c -; \
|
echo "$MONICA_SHA512 *monica.tar.bz2" | sha512sum -c -; \
|
||||||
\
|
\
|
||||||
mkdir /usr/src/monica; \
|
mkdir $MONICA_SRC; \
|
||||||
tar -xf monica.tar.bz2 -C /usr/src/monica --strip-components=1; \
|
tar -xf monica.tar.bz2 -C $MONICA_SRC --strip-components=1; \
|
||||||
rm monica.tar.bz2; \
|
rm monica.tar.bz2; \
|
||||||
\
|
\
|
||||||
cp /usr/src/monica/.env.example /usr/src/monica/.env; \
|
cp $MONICA_SRC/.env.example $MONICA_SRC/.env; \
|
||||||
chown -R www-data:www-data /usr/src/monica; \
|
chown -R www-data:www-data $MONICA_SRC; \
|
||||||
\
|
\
|
||||||
apk del .fetch-deps; \
|
apk del .fetch-deps; \
|
||||||
rm -rf /var/cache/apk/*
|
rm -rf /var/cache/apk/*
|
||||||
|
|
||||||
COPY upgrade.exclude \
|
COPY upgrade.exclude \
|
||||||
|
|||||||
@ -22,11 +22,11 @@ RUN set -ex; \
|
|||||||
|
|
||||||
# Install required PHP extensions
|
# Install required PHP extensions
|
||||||
RUN set -ex; \
|
RUN set -ex; \
|
||||||
\
|
\
|
||||||
savedAptMark="$(apt-mark showmanual)"; \
|
savedAptMark="$(apt-mark showmanual)"; \
|
||||||
\
|
\
|
||||||
apt-get update; \
|
apt-get update; \
|
||||||
apt-get install -y --no-install-recommends \
|
apt-get install -y --no-install-recommends \
|
||||||
libicu-dev \
|
libicu-dev \
|
||||||
zlib1g-dev \
|
zlib1g-dev \
|
||||||
libzip-dev \
|
libzip-dev \
|
||||||
@ -37,13 +37,13 @@ RUN set -ex; \
|
|||||||
libgmp-dev \
|
libgmp-dev \
|
||||||
libsodium-dev \
|
libsodium-dev \
|
||||||
libmemcached-dev \
|
libmemcached-dev \
|
||||||
; \
|
; \
|
||||||
\
|
\
|
||||||
debMultiarch="$(dpkg-architecture --query DEB_BUILD_MULTIARCH)"; \
|
debMultiarch="$(dpkg-architecture --query DEB_BUILD_MULTIARCH)"; \
|
||||||
if [ ! -e /usr/include/gmp.h ]; then ln -s /usr/include/$debMultiarch/gmp.h /usr/include/gmp.h; fi;\
|
if [ ! -e /usr/include/gmp.h ]; then ln -s /usr/include/$debMultiarch/gmp.h /usr/include/gmp.h; fi;\
|
||||||
docker-php-ext-configure intl; \
|
docker-php-ext-configure intl; \
|
||||||
docker-php-ext-configure gd --with-freetype-dir=/usr/include/ --with-jpeg-dir=/usr/include/ --with-png-dir=/usr/include/; \
|
docker-php-ext-configure gd --with-freetype-dir=/usr/include/ --with-jpeg-dir=/usr/include/ --with-png-dir=/usr/include/; \
|
||||||
docker-php-ext-configure gmp --with-gmp="/usr/include/$debMultiarch"; \
|
docker-php-ext-configure gmp --with-gmp="/usr/include/$debMultiarch"; \
|
||||||
docker-php-ext-install -j$(nproc) \
|
docker-php-ext-install -j$(nproc) \
|
||||||
intl \
|
intl \
|
||||||
zip \
|
zip \
|
||||||
@ -58,12 +58,12 @@ RUN set -ex; \
|
|||||||
sodium \
|
sodium \
|
||||||
mbstring \
|
mbstring \
|
||||||
opcache \
|
opcache \
|
||||||
; \
|
; \
|
||||||
\
|
\
|
||||||
# pecl will claim success even if one install fails, so we need to perform each install separately
|
# pecl will claim success even if one install fails, so we need to perform each install separately
|
||||||
pecl install APCu-5.1.18; \
|
pecl install APCu-5.1.18; \
|
||||||
pecl install memcached-3.1.5; \
|
pecl install memcached-3.1.5; \
|
||||||
pecl install redis-5.1.1; \
|
pecl install redis-5.1.1; \
|
||||||
\
|
\
|
||||||
docker-php-ext-enable \
|
docker-php-ext-enable \
|
||||||
apcu \
|
apcu \
|
||||||
@ -72,27 +72,27 @@ RUN set -ex; \
|
|||||||
; \
|
; \
|
||||||
\
|
\
|
||||||
# reset apt-mark's "manual" list so that "purge --auto-remove" will remove all build dependencies
|
# reset apt-mark's "manual" list so that "purge --auto-remove" will remove all build dependencies
|
||||||
apt-mark auto '.*' > /dev/null; \
|
apt-mark auto '.*' > /dev/null; \
|
||||||
apt-mark manual $savedAptMark; \
|
apt-mark manual $savedAptMark; \
|
||||||
ldd "$(php -r 'echo ini_get("extension_dir");')"/*.so \
|
ldd "$(php -r 'echo ini_get("extension_dir");')"/*.so \
|
||||||
| awk '/=>/ { print $3 }' \
|
| awk '/=>/ { print $3 }' \
|
||||||
| sort -u \
|
| sort -u \
|
||||||
| xargs -r dpkg-query -S \
|
| xargs -r dpkg-query -S \
|
||||||
| cut -d: -f1 \
|
| cut -d: -f1 \
|
||||||
| sort -u \
|
| sort -u \
|
||||||
| xargs -rt apt-mark manual; \
|
| xargs -rt apt-mark manual; \
|
||||||
\
|
\
|
||||||
apt-get purge -y --auto-remove -o APT::AutoRemove::RecommendsImportant=false; \
|
apt-get purge -y --auto-remove -o APT::AutoRemove::RecommendsImportant=false; \
|
||||||
rm -rf /var/lib/apt/lists/*; \
|
rm -rf /var/lib/apt/lists/*; \
|
||||||
\
|
\
|
||||||
if command -v a2enmod; then \
|
if command -v a2enmod; then \
|
||||||
a2enmod rewrite; \
|
a2enmod rewrite; \
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Set crontab for schedules
|
# Set crontab for schedules
|
||||||
RUN set -ex; \
|
RUN set -ex; \
|
||||||
\
|
\
|
||||||
mkdir -p /var/spool/cron/crontabs; \
|
mkdir -p /var/spool/cron/crontabs; \
|
||||||
echo '*/5 * * * * php /var/www/html/artisan schedule:run -v > /proc/1/fd/1 2> /proc/1/fd/2' > /var/spool/cron/crontabs/www-data
|
echo '*/5 * * * * php /var/www/html/artisan schedule:run -v > /proc/1/fd/1 2> /proc/1/fd/2' > /var/spool/cron/crontabs/www-data
|
||||||
|
|
||||||
# Opcache
|
# Opcache
|
||||||
@ -101,7 +101,7 @@ ENV PHP_OPCACHE_VALIDATE_TIMESTAMPS="0" \
|
|||||||
PHP_OPCACHE_MEMORY_CONSUMPTION="192" \
|
PHP_OPCACHE_MEMORY_CONSUMPTION="192" \
|
||||||
PHP_OPCACHE_MAX_WASTED_PERCENTAGE="10"
|
PHP_OPCACHE_MAX_WASTED_PERCENTAGE="10"
|
||||||
RUN { \
|
RUN { \
|
||||||
echo '[opcache]'; \
|
echo '[opcache]'; \
|
||||||
echo 'opcache.enable=1'; \
|
echo 'opcache.enable=1'; \
|
||||||
echo 'opcache.revalidate_freq=0'; \
|
echo 'opcache.revalidate_freq=0'; \
|
||||||
echo "opcache.validate_timestamps=${PHP_OPCACHE_VALIDATE_TIMESTAMPS}"; \
|
echo "opcache.validate_timestamps=${PHP_OPCACHE_VALIDATE_TIMESTAMPS}"; \
|
||||||
@ -110,34 +110,40 @@ RUN { \
|
|||||||
echo "opcache.max_wasted_percentage=${PHP_OPCACHE_MAX_WASTED_PERCENTAGE}"; \
|
echo "opcache.max_wasted_percentage=${PHP_OPCACHE_MAX_WASTED_PERCENTAGE}"; \
|
||||||
echo 'opcache.interned_strings_buffer=16'; \
|
echo 'opcache.interned_strings_buffer=16'; \
|
||||||
echo 'opcache.fast_shutdown=1'; \
|
echo 'opcache.fast_shutdown=1'; \
|
||||||
} > /usr/local/etc/php/conf.d/opcache-recommended.ini; \
|
} > $PHP_INI_DIR/conf.d/opcache-recommended.ini; \
|
||||||
\
|
\
|
||||||
echo 'apc.enable_cli=1' >> /usr/local/etc/php/conf.d/docker-php-ext-apcu.ini; \
|
echo 'apc.enable_cli=1' >> $PHP_INI_DIR/conf.d/docker-php-ext-apcu.ini; \
|
||||||
\
|
\
|
||||||
echo 'memory_limit=512M' > /usr/local/etc/php/conf.d/memory-limit.ini
|
echo 'memory_limit=512M' > $PHP_INI_DIR/conf.d/memory-limit.ini
|
||||||
|
|
||||||
# Sentry
|
# Sentry
|
||||||
RUN mkdir -p /root/.local/bin; \
|
RUN if [ $(uname -m) = "x86_64" ]; then \
|
||||||
curl -sL https://sentry.io/get-cli/ | INSTALL_DIR=/root/.local/bin bash
|
PLATFORM=$(uname -s); \
|
||||||
|
if [ "$PLATFORM" = "Linux" -o "$PLATFORM" = "Windows" -o "$PLATFORM" = "Darwin" ]; then \
|
||||||
|
mkdir -p /root/.local/bin; \
|
||||||
|
curl -sL https://sentry.io/get-cli/ | INSTALL_DIR=/root/.local/bin bash; \
|
||||||
|
fi \
|
||||||
|
fi
|
||||||
|
|
||||||
VOLUME /var/www/html
|
VOLUME /var/www/html
|
||||||
|
|
||||||
# Define Monica version and expected SHA512 signature
|
# Define Monica version and expected SHA512 signature
|
||||||
ENV MONICA_VERSION v2.16.0
|
ENV MONICA_VERSION v2.16.0
|
||||||
ENV MONICA_SHA512 f2d1a434b5615bcd100388066854dfd36c81f403e817f45a21d4c04ec9ee022339c25334913586a51e763928d17d8b3fa79b6bf1883cac6fffe1aabfbd14ae3c
|
ENV MONICA_SHA512 f2d1a434b5615bcd100388066854dfd36c81f403e817f45a21d4c04ec9ee022339c25334913586a51e763928d17d8b3fa79b6bf1883cac6fffe1aabfbd14ae3c
|
||||||
|
ENV MONICA_SRC /usr/src/monica
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
RUN set -eu; \
|
RUN set -eu; \
|
||||||
curl -fsSL -o monica.tar.bz2 "https://github.com/monicahq/monica/releases/download/${MONICA_VERSION}/monica-${MONICA_VERSION}.tar.bz2"; \
|
curl -fsSL -o monica.tar.bz2 "https://github.com/monicahq/monica/releases/download/${MONICA_VERSION}/monica-${MONICA_VERSION}.tar.bz2"; \
|
||||||
echo "$MONICA_SHA512 *monica.tar.bz2" | sha512sum -c -; \
|
echo "$MONICA_SHA512 *monica.tar.bz2" | sha512sum -c -; \
|
||||||
\
|
\
|
||||||
mkdir /usr/src/monica; \
|
mkdir $MONICA_SRC; \
|
||||||
tar -xf monica.tar.bz2 -C /usr/src/monica --strip-components=1; \
|
tar -xf monica.tar.bz2 -C $MONICA_SRC --strip-components=1; \
|
||||||
rm monica.tar.bz2; \
|
rm monica.tar.bz2; \
|
||||||
\
|
\
|
||||||
cp /usr/src/monica/.env.example /usr/src/monica/.env; \
|
cp $MONICA_SRC/.env.example $MONICA_SRC/.env; \
|
||||||
chown -R www-data:www-data /usr/src/monica
|
chown -R www-data:www-data $MONICA_SRC
|
||||||
|
|
||||||
COPY upgrade.exclude \
|
COPY upgrade.exclude \
|
||||||
/usr/local/share/
|
/usr/local/share/
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user