Оптимизация Dockerfile
Some checks failed
Build and Push Docker Image / test (push) Failing after 3s
Build and Push Docker Image / build (push) Failing after 25s

This commit is contained in:
brusnitsyn
2026-02-27 15:36:55 +09:00
parent 47543fedba
commit d93301ff8b

View File

@@ -1,93 +1,63 @@
# Этап 1: PHP зависимости # Этап 1: Сборка PHP зависимостей
FROM dh-mirror.gitverse.ru/php:8.3-fpm AS phpbuild FROM webdevops/php:8.3-alpine AS php-build
# Установка системных зависимостей ENV WEB_DOCUMENT_ROOT=/var/www/html/public
RUN apt-get update && apt-get install -y \ ENV PHP_DATE_TIMEZONE=UTC
ENV PHP_DISPLAY_ERRORS=0
ENV PHP_MEMORY_LIMIT=512M
ENV PHP_MAX_EXECUTION_TIME=300
ENV PHP_OPCACHE_ENABLE=1
ENV PHP_OPCACHE_MEMORY_CONSUMPTION=256
# Проверяем установленные расширения (для отладки)
RUN php -m && \
php -i | grep gd && \
php -i | grep redis
# Установка дополнительных системных зависимостей, если нужно
RUN apk update && apk add --no-cache \
git \ git \
curl \
wget \
unzip \ unzip \
# Для сборки некоторых зависимостей Composer
libzip-dev \ libzip-dev \
libxml2-dev \ oniguruma-dev \
libicu-dev \ && docker-run-bootstrap
libonig-dev \
libpng-dev \
libjpeg-dev \
libfreetype6-dev \
libwebp-dev \
libpq-dev \
libxslt1-dev \
libexif-dev \
libffi-dev \
pkg-config \
libssl-dev \
&& rm -rf /var/lib/apt/lists/*
# Установка PHP расширений
RUN docker-php-ext-configure gd \
--with-freetype \
--with-jpeg \
--with-webp \
&& docker-php-ext-install -j$(nproc) \
bcmath \
intl \
mbstring \
zip \
opcache \
pdo \
pdo_mysql \
pdo_pgsql \
gd \
exif \
sockets \
xsl \
ffi \
pcntl
# Установка Redis расширения
RUN pecl install redis && docker-php-ext-enable redis
# Настройка opcache для production
RUN echo "opcache.enable=1" >> /usr/local/etc/php/conf.d/opcache.ini && \
echo "opcache.memory_consumption=256" >> /usr/local/etc/php/conf.d/opcache.ini && \
echo "opcache.interned_strings_buffer=32" >> /usr/local/etc/php/conf.d/opcache.ini && \
echo "opcache.max_accelerated_files=32531" >> /usr/local/etc/php/conf.d/opcache.ini && \
echo "opcache.validate_timestamps=0" >> /usr/local/etc/php/conf.d/opcache.ini
# Установка Composer # Установка Composer
COPY --from=dh-mirror.gitverse.ru/composer:2.7 /usr/bin/composer /usr/bin/composer COPY --from=composer:2.7 /usr/bin/composer /usr/bin/composer
WORKDIR /var/www WORKDIR /var/www/html
# Копирование файлов для установки зависимостей # Копируем только файлы зависимостей (для лучшего кэширования слоев)
COPY composer.json composer.lock ./ COPY composer.json composer.lock ./
# Установка PHP зависимостей # Установка PHP зависимостей (NO DEV для production)
RUN composer install \ RUN composer install \
--no-interaction \
--no-progress \ --no-progress \
--no-scripts \ --no-scripts \
--prefer-dist \ --prefer-dist \
--optimize-autoloader \ --optimize-autoloader \
--apcu-autoloader --apcu-autoloader \
--no-dev
# Копируем исходный код # Копируем остальной код
COPY . . COPY . .
# Установка прав # Выполняем скрипты post-install
RUN chown -R www-data:www-data /var/www && \ #RUN composer run-script post-install-cmd
chmod -R 775 /var/www/storage /var/www/bootstrap/cache
# Этап 2: Сборка фронтенда (Inertia + Vue 3) # Оптимизируем автозагрузчик
FROM dh-mirror.gitverse.ru/node:20 AS jsbuild RUN composer dump-autoload --optimize
# Установка дополнительных зависимостей для сборки # Устанавливаем права
RUN apt-get update && apt-get install -y \ RUN chown -R application:application /var/www/html && \
python3 \ chmod -R 775 /var/www/html/storage /var/www/html/bootstrap/cache
make \
g++ \
&& rm -rf /var/lib/apt/lists/*
WORKDIR /var/www # Этап 2: Сборка фронтенда
FROM node:20-alpine AS node-build
WORKDIR /var/www/html
# Копируем зависимости Node.js # Копируем зависимости Node.js
COPY package.json package-lock.json* ./ COPY package.json package-lock.json* ./
@@ -99,109 +69,77 @@ RUN npm ci \
# Копируем файлы для сборки фронтенда # Копируем файлы для сборки фронтенда
COPY vite.config.js ./ COPY vite.config.js ./
COPY resources/js ./resources/js/ COPY resources/ ./resources/
COPY resources/css ./resources/css/
# Сборка ассетов Vite # Сборка ассетов
RUN npm run build RUN npm run build
# Этап 3: Финальный образ # Этап 3: Финальный production образ
FROM dh-mirror.gitverse.ru/php:8.3-fpm FROM webdevops/php-nginx:8.3-alpine
# Установка runtime зависимостей # Production настройки
RUN apt-get update && apt-get install -y \ ENV WEB_DOCUMENT_ROOT=/var/www/html/public
libxml2 \ ENV PHP_DATE_TIMEZONE=UTC
libonig5 \ ENV PHP_DISPLAY_ERRORS=0
libpng16-16 \ ENV PHP_MEMORY_LIMIT=512M
libjpeg62-turbo \ ENV PHP_MAX_EXECUTION_TIME=300
libfreetype6 \ ENV PHP_POST_MAX_SIZE=100M
libwebp7 \ ENV PHP_UPLOAD_MAX_FILESIZE=100M
libpq5 \ ENV PHP_OPCACHE_ENABLE=1
libxslt1.1 \ ENV PHP_OPCACHE_MEMORY_CONSUMPTION=256
libexif12 \ ENV PHP_OPCACHE_MAX_ACCELERATED_FILES=32531
libffi8 \ ENV PHP_OPCACHE_VALIDATE_TIMESTAMPS=0
ENV NGINX_WORKER_PROCESSES=auto
ENV NGINX_WORKER_CONNECTIONS=1024
# Включаем дополнительные сервисы
#RUN docker-service enable cron && \
# docker-service enable supervisor
# Устанавливаем дополнительные пакеты, если нужны
RUN apk update && apk add --no-cache \
supervisor \ supervisor \
nginx \ # Для планировщика Laravel
cron \ dcron \
&& rm -rf /var/lib/apt/lists/* # Дополнительные утилиты
nano \
# Установка системных зависимостей htop \
RUN apt-get update && apt-get install -y \ && docker-run-bootstrap
git \
curl \
wget \
unzip \
libzip-dev \
libxml2-dev \
libicu-dev \
libonig-dev \
libpng-dev \
libjpeg-dev \
libfreetype6-dev \
libwebp-dev \
libpq-dev \
libxslt1-dev \
libexif-dev \
libffi-dev \
pkg-config \
libssl-dev \
&& rm -rf /var/lib/apt/lists/*
# Установка PHP расширений
RUN docker-php-ext-configure gd \
--with-freetype \
--with-jpeg \
--with-webp \
&& docker-php-ext-install -j$(nproc) \
bcmath \
intl \
mbstring \
zip \
opcache \
pdo \
pdo_mysql \
pdo_pgsql \
gd \
exif \
sockets \
xsl \
ffi \
pcntl
# Установка Redis расширения
RUN pecl install redis && docker-php-ext-enable redis
# Настройка opcache для production
RUN echo "opcache.enable=1" >> /usr/local/etc/php/conf.d/opcache.ini && \
echo "opcache.memory_consumption=256" >> /usr/local/etc/php/conf.d/opcache.ini && \
echo "opcache.interned_strings_buffer=32" >> /usr/local/etc/php/conf.d/opcache.ini && \
echo "opcache.max_accelerated_files=32531" >> /usr/local/etc/php/conf.d/opcache.ini && \
echo "opcache.validate_timestamps=0" >> /usr/local/etc/php/conf.d/opcache.ini
# Копируем PHP расширения из первого этапа
#COPY --from=phpbuild /usr/local/etc/php/conf.d/ /usr/local/etc/php/conf.d/
#COPY --from=phpbuild /usr/local/lib/php/extensions/no-debug-non-zts-20230831/ /usr/local/lib/php/extensions/no-debug-non-zts-20230831/
#COPY --from=phpbuild /usr/local/bin/ /usr/local/bin/
# Копируем конфигурации # Копируем конфигурации
COPY docker/nginx.conf /etc/nginx/nginx.conf COPY docker/nginx.conf /etc/nginx/nginx.conf
COPY docker/app.conf /etc/nginx/conf.d/default.conf COPY docker/app.conf /etc/nginx/conf.d/default.conf
COPY docker/supervisord.conf /etc/supervisor/supervisord.conf COPY docker/supervisord.conf /etc/supervisor/supervisord.conf
WORKDIR /var/www WORKDIR /var/www/html
# Копируем приложение # Копируем приложение из этапов сборки
COPY --chown=www-data:www-data --from=phpbuild /var/www . COPY --chown=application:application --from=php-build /var/www/html .
COPY --chown=www-data:www-data --from=jsbuild /var/www/public/build ./public/build COPY --chown=application:application --from=node-build /var/www/html/public/build ./public/build
COPY --chown=www-data:www-data --from=jsbuild /var/www/node_modules ./node_modules
# Настройка прав и оптимизация Laravel # Настраиваем права
RUN mkdir -p /var/log/supervisor && \ RUN chown -R application:application /var/www/html && \
chown -R www-data:www-data /var/www /var/log/supervisor && \ chmod -R 775 /var/www/html/storage /var/www/html/bootstrap/cache
chmod -R 775 /var/www/storage /var/www/bootstrap/cache
# Создание ссылки на Storage # Создаем символические ссылки
RUN php artisan storage:link RUN php artisan storage:link
# Кэшируем конфигурации Laravel для production
#RUN php artisan config:cache && \
# php artisan route:cache && \
# php artisan view:cache
# Удаляем все тестовые файлы PHP (для docker-squash)
# https://github.com/shinsenter/docker-squash
RUN rm -rf /usr/src/php \
&& rm -f /usr/src/php.tar.xz 2>/dev/null || true \
&& rm -rf /usr/local/lib/php/test \
&& rm -rf /usr/local/lib/php/doc
# Health check
HEALTHCHECK --interval=30s --timeout=3s --start-period=5s --retries=3 \
CMD curl -f http://localhost/health || exit 1
EXPOSE 80 EXPOSE 80
CMD ["/usr/bin/supervisord", "-c", "/etc/supervisor/supervisord.conf"]
CMD ["supervisord", "-c", "/etc/supervisor.d/supervisord.conf"]