mirror of
https://github.com/kevinpapst/kimai2.git
synced 2025-01-10 11:37:35 +00:00
9e736b26f6
* ignore certain connection errors on startup * remove invalid code that checks for the existence of the migration table * fetch kimai code via tar archive instead of git clone, to respect .gitattributes
330 lines
12 KiB
Docker
330 lines
12 KiB
Docker
# _ ___ _
|
|
# | |/ (_)_ __ ___ __ _(_)
|
|
# | ' /| | '_ ` _ \ / _` | |
|
|
# | . \| | | | | | | (_| | |
|
|
# |_|\_\_|_| |_| |_|\__,_|_|
|
|
#
|
|
# Kimai images for:
|
|
# - plain PHP FPM (kimai/kimai2:fpm)
|
|
# - Apache with PHP (kimai/kimai2:apache)
|
|
# - Development (kimai/kimai2:dev)
|
|
# ---------------------------------------------------------------------
|
|
# For local testing by maintainer:
|
|
#
|
|
# docker build --no-cache -t kimai-fpm --build-arg BASE=fpm .
|
|
# docker build --no-cache -t kimai-apache --build-arg BASE=apache .
|
|
# docker run -d --name kimai-apache-app kimai-apache
|
|
# docker exec -ti kimai-apache-app /bin/bash
|
|
# ---------------------------------------------------------------------
|
|
# Official PHP images: https://hub.docker.com/_/php/
|
|
# https://github.com/docker-library/docs/blob/master/php/README.md#supported-tags-and-respective-dockerfile-links
|
|
# Pass-through Arguments: https://benkyriakou.com/posts/docker-args-empty
|
|
# Best practices: https://docs.docker.com/build/building/best-practices/
|
|
# ---------------------------------------------------------------------
|
|
|
|
# Source base, one of: fpm, apache
|
|
ARG BASE="fpm"
|
|
# Kimai branch/tag to run
|
|
ARG KIMAI="main"
|
|
# Timezone for images
|
|
ARG TIMEZONE="Europe/Berlin"
|
|
|
|
###########################
|
|
# Shared tools
|
|
###########################
|
|
|
|
# composer base image
|
|
FROM composer:latest AS composer
|
|
|
|
###########################
|
|
# PHP extensions
|
|
###########################
|
|
|
|
# fpm alpine php extension base
|
|
FROM php:8.3-fpm-alpine AS fpm-php-ext-base
|
|
RUN apk add --no-cache \
|
|
# build-tools
|
|
autoconf \
|
|
dpkg \
|
|
dpkg-dev \
|
|
file \
|
|
g++ \
|
|
gcc \
|
|
icu-dev \
|
|
libatomic \
|
|
libc-dev \
|
|
libgomp \
|
|
libmagic \
|
|
m4 \
|
|
make \
|
|
mpc1 \
|
|
mpfr4 \
|
|
musl-dev \
|
|
perl \
|
|
re2c \
|
|
# gd
|
|
freetype-dev \
|
|
libpng-dev \
|
|
# icu
|
|
icu-dev \
|
|
icu-data-full \
|
|
# ldap
|
|
openldap-dev \
|
|
libldap \
|
|
# zip
|
|
libzip-dev \
|
|
# xsl
|
|
libxslt-dev
|
|
|
|
# apache debian php extension base
|
|
FROM php:8.3-apache-bookworm AS apache-php-ext-base
|
|
RUN apt-get update && \
|
|
apt-get install -y \
|
|
libldap2-dev \
|
|
libicu-dev \
|
|
libpng-dev \
|
|
libzip-dev \
|
|
libxslt1-dev \
|
|
libfreetype6-dev
|
|
|
|
# php extension gd - 13.86s
|
|
FROM ${BASE}-php-ext-base AS php-ext-gd
|
|
RUN docker-php-ext-configure gd \
|
|
--with-freetype && \
|
|
docker-php-ext-install -j$(nproc) gd
|
|
|
|
# php extension intl : 15.26s
|
|
FROM ${BASE}-php-ext-base AS php-ext-intl
|
|
RUN docker-php-ext-install -j$(nproc) intl
|
|
|
|
# php extension ldap : 8.45s
|
|
FROM ${BASE}-php-ext-base AS php-ext-ldap
|
|
RUN docker-php-ext-configure ldap && \
|
|
docker-php-ext-install -j$(nproc) ldap
|
|
|
|
# php extension pdo_mysql : 6.14s
|
|
FROM ${BASE}-php-ext-base AS php-ext-pdo_mysql
|
|
RUN docker-php-ext-install -j$(nproc) pdo_mysql
|
|
|
|
# php extension zip : 8.18s
|
|
FROM ${BASE}-php-ext-base AS php-ext-zip
|
|
RUN docker-php-ext-install -j$(nproc) zip
|
|
|
|
# php extension xsl : ?.?? s
|
|
FROM ${BASE}-php-ext-base AS php-ext-xsl
|
|
RUN docker-php-ext-install -j$(nproc) xsl
|
|
|
|
# php extension opcache
|
|
FROM ${BASE}-php-ext-base AS php-ext-opcache
|
|
RUN docker-php-ext-install -j$(nproc) opcache
|
|
|
|
###########################
|
|
# fpm base build
|
|
###########################
|
|
|
|
FROM php:8.3-fpm-alpine AS fpm-base
|
|
ARG TIMEZONE
|
|
RUN apk add --no-cache \
|
|
bash \
|
|
coreutils \
|
|
freetype \
|
|
haveged \
|
|
icu \
|
|
icu-data-full \
|
|
libldap \
|
|
libpng \
|
|
libzip \
|
|
libxslt-dev \
|
|
fcgi \
|
|
tzdata && \
|
|
touch /use_fpm && \
|
|
sed -i "s/;ping.path/ping.path/g" /usr/local/etc/php-fpm.d/www.conf && \
|
|
sed -i "s/;access.suppress_path\[\] = \/ping/access.suppress_path\[\] = \/ping/g" /usr/local/etc/php-fpm.d/www.conf
|
|
|
|
EXPOSE 9000
|
|
|
|
HEALTHCHECK --interval=20s --timeout=10s --retries=3 \
|
|
CMD \
|
|
SCRIPT_NAME=/ping \
|
|
SCRIPT_FILENAME=/ping \
|
|
REQUEST_METHOD=GET \
|
|
cgi-fcgi -bind -connect 127.0.0.1:9000 || exit 1
|
|
|
|
###########################
|
|
# apache base build
|
|
###########################
|
|
|
|
FROM php:8.3-apache-bookworm AS apache-base
|
|
ARG TIMEZONE
|
|
RUN apt-get update && \
|
|
apt-get install -y \
|
|
bash \
|
|
haveged \
|
|
libicu72 \
|
|
libldap-common \
|
|
libpng16-16 \
|
|
libzip4 \
|
|
libxslt1.1 \
|
|
libfreetype6 \
|
|
unzip && \
|
|
echo "Listen 8001" > /etc/apache2/ports.conf && \
|
|
a2enmod rewrite && \
|
|
touch /use_apache
|
|
|
|
COPY .docker/000-default.conf /etc/apache2/sites-available/000-default.conf
|
|
|
|
EXPOSE 8001
|
|
|
|
HEALTHCHECK --interval=20s --timeout=10s --retries=3 \
|
|
CMD curl -f http://127.0.0.1:8001 || exit 1
|
|
|
|
###########################
|
|
# global base build
|
|
###########################
|
|
|
|
FROM ${BASE}-base AS php-base
|
|
ARG TIMEZONE
|
|
|
|
ENV TIMEZONE=${TIMEZONE}
|
|
RUN ln -snf /usr/share/zoneinfo/${TIMEZONE} /etc/localtime && echo ${TIMEZONE} > /etc/timezone && \
|
|
# make composer home dir
|
|
mkdir /composer && \
|
|
chown -R www-data:www-data /composer
|
|
|
|
# copy composer
|
|
COPY --from=composer /usr/bin/composer /usr/bin/composer
|
|
|
|
# copy php extensions
|
|
|
|
# PHP extension xsl
|
|
COPY --from=php-ext-xsl /usr/local/etc/php/conf.d/docker-php-ext-xsl.ini /usr/local/etc/php/conf.d/docker-php-ext-xsl.ini
|
|
COPY --from=php-ext-xsl /usr/local/lib/php/extensions/no-debug-non-zts-20230831/xsl.so /usr/local/lib/php/extensions/no-debug-non-zts-20230831/xsl.so
|
|
# PHP extension pdo_mysql
|
|
COPY --from=php-ext-pdo_mysql /usr/local/etc/php/conf.d/docker-php-ext-pdo_mysql.ini /usr/local/etc/php/conf.d/docker-php-ext-pdo_mysql.ini
|
|
COPY --from=php-ext-pdo_mysql /usr/local/lib/php/extensions/no-debug-non-zts-20230831/pdo_mysql.so /usr/local/lib/php/extensions/no-debug-non-zts-20230831/pdo_mysql.so
|
|
# PHP extension zip
|
|
COPY --from=php-ext-zip /usr/local/etc/php/conf.d/docker-php-ext-zip.ini /usr/local/etc/php/conf.d/docker-php-ext-zip.ini
|
|
COPY --from=php-ext-zip /usr/local/lib/php/extensions/no-debug-non-zts-20230831/zip.so /usr/local/lib/php/extensions/no-debug-non-zts-20230831/zip.so
|
|
# PHP extension ldap
|
|
COPY --from=php-ext-ldap /usr/local/etc/php/conf.d/docker-php-ext-ldap.ini /usr/local/etc/php/conf.d/docker-php-ext-ldap.ini
|
|
COPY --from=php-ext-ldap /usr/local/lib/php/extensions/no-debug-non-zts-20230831/ldap.so /usr/local/lib/php/extensions/no-debug-non-zts-20230831/ldap.so
|
|
# PHP extension gd
|
|
COPY --from=php-ext-gd /usr/local/etc/php/conf.d/docker-php-ext-gd.ini /usr/local/etc/php/conf.d/docker-php-ext-gd.ini
|
|
COPY --from=php-ext-gd /usr/local/lib/php/extensions/no-debug-non-zts-20230831/gd.so /usr/local/lib/php/extensions/no-debug-non-zts-20230831/gd.so
|
|
# PHP extension intl
|
|
COPY --from=php-ext-intl /usr/local/etc/php/conf.d/docker-php-ext-intl.ini /usr/local/etc/php/conf.d/docker-php-ext-intl.ini
|
|
COPY --from=php-ext-intl /usr/local/lib/php/extensions/no-debug-non-zts-20230831/intl.so /usr/local/lib/php/extensions/no-debug-non-zts-20230831/intl.so
|
|
# PHP extension opcache
|
|
COPY --from=php-ext-opcache /usr/local/etc/php/conf.d/docker-php-ext-opcache.ini /usr/local/etc/php/conf.d/docker-php-ext-opcache.ini
|
|
|
|
###########################
|
|
# fetch Kimai sources
|
|
###########################
|
|
|
|
FROM alpine:latest AS git-prod
|
|
ARG KIMAI
|
|
ARG TIMEZONE
|
|
# the convention in the Kimai repository is: tags are always version numbers, branch names always start with a letter
|
|
# if the KIMAI variable starts with a number (e.g. 2.24.0) we assume its a tag, otherwise its a branch
|
|
RUN [[ $KIMAI =~ ^[0-9] ]] && export REF='tags' || export REF='heads' && \
|
|
wget -O "/opt/kimai.tar.gz" "https://github.com/kimai/kimai/archive/refs/${REF}/${KIMAI}.tar.gz" && \
|
|
tar -xpzf /opt/kimai.tar.gz -C /opt/ && \
|
|
mv /opt/kimai-${KIMAI} /opt/kimai
|
|
|
|
###########################
|
|
# global base build
|
|
###########################
|
|
|
|
FROM php-base AS base
|
|
ARG KIMAI
|
|
ARG TIMEZONE
|
|
|
|
LABEL org.opencontainers.image.title="Kimai" \
|
|
org.opencontainers.image.description="Kimai is a time-tracking application." \
|
|
org.opencontainers.image.authors="Kimai Community" \
|
|
org.opencontainers.image.url="https://www.kimai.org/" \
|
|
org.opencontainers.image.documentation="https://www.kimai.org/documentation/" \
|
|
org.opencontainers.image.source="https://github.com/kimai/kimai" \
|
|
org.opencontainers.image.version="${KIMAI}" \
|
|
org.opencontainers.image.vendor="Kevin Papst" \
|
|
org.opencontainers.image.licenses="AGPL-3.0"
|
|
|
|
ENV KIMAI=${KIMAI}
|
|
ENV TIMEZONE=${TIMEZONE}
|
|
RUN ln -snf /usr/share/zoneinfo/${TIMEZONE} /etc/localtime && echo ${TIMEZONE} > /etc/timezone && \
|
|
mkdir -p /composer && \
|
|
chown -R www-data:www-data /composer
|
|
|
|
# copy startup script & DB checking script
|
|
COPY .docker/dbtest.php /dbtest.php
|
|
COPY .docker/entrypoint.sh /entrypoint.sh
|
|
|
|
ENV DATABASE_URL="mysql://kimai:kimai@127.0.0.1:3306/kimai?charset=utf8mb4&serverVersion=8.3"
|
|
ENV APP_SECRET=change_this_to_something_unique
|
|
# The default container name for nginx is nginx
|
|
ENV TRUSTED_PROXIES=nginx,localhost,127.0.0.1
|
|
ENV MAILER_FROM=kimai@example.com
|
|
ENV MAILER_URL=null://localhost
|
|
ENV ADMINPASS=
|
|
ENV ADMINMAIL=
|
|
ENV USER_ID=
|
|
ENV GROUP_ID=
|
|
# default values to configure composer behavior
|
|
ENV COMPOSER_MEMORY_LIMIT=-1
|
|
ENV COMPOSER_ALLOW_SUPERUSER=1
|
|
|
|
VOLUME [ "/opt/kimai/var" ]
|
|
|
|
CMD [ "/entrypoint.sh" ]
|
|
|
|
###########################
|
|
# final builds
|
|
###########################
|
|
|
|
# development build
|
|
FROM base AS dev
|
|
# copy kimai develop source
|
|
COPY --from=git-prod --chown=www-data:www-data /opt/kimai /opt/kimai
|
|
COPY .docker /assets
|
|
# do the composer deps installation
|
|
RUN \
|
|
export COMPOSER_HOME=/composer && \
|
|
composer --no-ansi install --working-dir=/opt/kimai --optimize-autoloader && \
|
|
composer --no-ansi clearcache && \
|
|
composer --no-ansi require --working-dir=/opt/kimai laminas/laminas-ldap && \
|
|
cp /usr/local/etc/php/php.ini-development /usr/local/etc/php/php.ini && \
|
|
chown -R www-data:www-data /opt/kimai /usr/local/etc/php/php.ini && \
|
|
mkdir -p /opt/kimai/var/logs && chmod 777 /opt/kimai/var/logs && \
|
|
sed "s/128M/-1/g" /usr/local/etc/php/php.ini-development > /opt/kimai/php-cli.ini && \
|
|
sed -i "s/env php/env -S php -c \/opt\/kimai\/php-cli.ini/g" /opt/kimai/bin/console && \
|
|
/opt/kimai/bin/console kimai:version | awk '{print $2}' > /opt/kimai/version.txt
|
|
ENV APP_ENV=dev
|
|
ENV DATABASE_URL=
|
|
ENV memory_limit=512M
|
|
|
|
# the "prod" stage (production build) is configured as last stage in the file, as this is the default target in BuildKit
|
|
FROM base AS prod
|
|
# copy kimai production source
|
|
COPY --from=git-prod --chown=www-data:www-data /opt/kimai /opt/kimai
|
|
COPY .docker /assets
|
|
# do the composer deps installation
|
|
RUN \
|
|
export COMPOSER_HOME=/composer && \
|
|
composer --no-ansi install --working-dir=/opt/kimai --no-dev --optimize-autoloader && \
|
|
composer --no-ansi clearcache && \
|
|
composer --no-ansi require --update-no-dev --working-dir=/opt/kimai laminas/laminas-ldap && \
|
|
cp /usr/local/etc/php/php.ini-production /usr/local/etc/php/php.ini && \
|
|
sed -i "s/expose_php = On/expose_php = Off/g" /usr/local/etc/php/php.ini && \
|
|
sed -i "s/;opcache.enable=1/opcache.enable=1/g" /usr/local/etc/php/php.ini && \
|
|
sed -i "s/;opcache.memory_consumption=128/opcache.memory_consumption=256/g" /usr/local/etc/php/php.ini && \
|
|
sed -i "s/;opcache.interned_strings_buffer=8/opcache.interned_strings_buffer=24/g" /usr/local/etc/php/php.ini && \
|
|
sed -i "s/;opcache.max_accelerated_files=10000/opcache.max_accelerated_files=100000/g" /usr/local/etc/php/php.ini && \
|
|
sed -i "s/opcache.validate_timestamps=1/opcache.validate_timestamps=0/g" /usr/local/etc/php/php.ini && \
|
|
sed -i "s/session.gc_maxlifetime = 1440/session.gc_maxlifetime = 604800/g" /usr/local/etc/php/php.ini && \
|
|
mkdir -p /opt/kimai/var/logs && chmod 777 /opt/kimai/var/logs && \
|
|
sed "s/128M/-1/g" /usr/local/etc/php/php.ini-development > /opt/kimai/php-cli.ini && \
|
|
chown -R www-data:www-data /opt/kimai /usr/local/etc/php/php.ini && \
|
|
/opt/kimai/bin/console kimai:version | awk '{print $2}' > /opt/kimai/version.txt
|
|
ENV APP_ENV=prod
|
|
ENV DATABASE_URL=
|
|
ENV memory_limit=512M
|