Добавил поддержку драйверов sqlsrv + msodbcsql

Исправление openssl подключения к бд мис
This commit is contained in:
brusnitsyn
2026-06-03 17:12:02 +09:00
parent aa0cd0c449
commit 72a8980524
3 changed files with 465 additions and 50 deletions

View File

@@ -9,29 +9,48 @@ 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
# Установка дополнительных системных зависимостей, если нужно
# Установка системных зависимостей + Microsoft ODBC + sqlsrv
RUN apk update && apk add --no-cache \
git \
unzip \
# Для сборки некоторых зависимостей Composer
libzip-dev \
oniguruma-dev \
unixodbc-dev \
autoconf \
make \
g++ \
curl \
gnupg \
&& case $(uname -m) in \
x86_64) architecture="amd64" ;; \
arm64) architecture="arm64" ;; \
*) echo "Unsupported architecture"; exit 1 ;; \
esac \
&& curl -O https://download.microsoft.com/download/0b3d5518-b4a7-4a2b-afc7-7ee9e967f93c/msodbcsql18_18.6.2.1-1_${architecture}.apk \
&& ACCEPT_EULA=Y apk add --allow-untrusted msodbcsql18_18.6.2.1-1_${architecture}.apk \
&& rm msodbcsql18_18.6.2.1-1_${architecture}.apk \
&& pecl install sqlsrv pdo_sqlsrv \
&& docker-php-ext-enable sqlsrv pdo_sqlsrv \
&& apk del autoconf make g++ \
&& docker-run-bootstrap
# Чистим pecl мусор
RUN rm -rf /usr/local/lib/php/test \
&& rm -rf /usr/local/lib/php/doc \
&& rm -rf /tmp/pear \
&& rm -rf /usr/src/php \
&& rm -f /usr/src/php.tar.xz 2>/dev/null || true
# Фикс OpenSSL 3 совместимости с SQL Server 2016
COPY docker/openssl.cnf /etc/ssl/openssl.cnf
# Установка Composer
COPY --from=composer:2.7 /usr/bin/composer /usr/bin/composer
WORKDIR /var/www/html
# Копируем только файлы зависимостей (для лучшего кэширования слоев)
COPY composer.json composer.lock ./
# Установка PHP зависимостей (NO DEV для production)
RUN composer install \
--no-interaction \
--no-progress \
@@ -41,16 +60,10 @@ RUN composer install \
--apcu-autoloader \
--no-dev
# Копируем остальной код
COPY . .
# Выполняем скрипты post-install
#RUN composer run-script post-install-cmd
# Оптимизируем автозагрузчик
RUN composer dump-autoload --optimize
# Устанавливаем права
RUN chown -R application:application /var/www/html && \
chmod -R 775 /var/www/html/storage /var/www/html/bootstrap/cache
@@ -59,25 +72,20 @@ FROM node:20-alpine AS node-build
WORKDIR /var/www/html
# Копируем зависимости Node.js
COPY package.json package-lock.json* ./
# Установка зависимостей Node.js
RUN npm ci \
--no-audit \
--progress=false
# Копируем файлы для сборки фронтенда
COPY vite.config.js ./
COPY resources/ ./resources/
# Сборка ассетов
RUN npm run build
# Этап 3: Финальный production образ
FROM webdevops/php-nginx:8.3-alpine
# Production настройки
ENV WEB_DOCUMENT_ROOT=/var/www/html/public
ENV PHP_DATE_TIMEZONE=UTC
ENV PHP_DISPLAY_ERRORS=0
@@ -92,51 +100,55 @@ 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
# Устанавливаем дополнительные пакеты, если нужны
# Установка системных зависимостей + Microsoft ODBC + sqlsrv
RUN apk update && apk add --no-cache \
supervisor \
# Для планировщика Laravel
dcron \
# Дополнительные утилиты
nano \
htop \
git \
unzip \
libzip-dev \
oniguruma-dev \
unixodbc-dev \
autoconf \
make \
g++ \
curl \
gnupg \
&& case $(uname -m) in \
x86_64) architecture="amd64" ;; \
arm64) architecture="arm64" ;; \
*) echo "Unsupported architecture"; exit 1 ;; \
esac \
&& curl -O https://download.microsoft.com/download/0b3d5518-b4a7-4a2b-afc7-7ee9e967f93c/msodbcsql18_18.6.2.1-1_${architecture}.apk \
&& ACCEPT_EULA=Y apk add --allow-untrusted msodbcsql18_18.6.2.1-1_${architecture}.apk \
&& rm msodbcsql18_18.6.2.1-1_${architecture}.apk \
&& pecl install sqlsrv pdo_sqlsrv \
&& docker-php-ext-enable sqlsrv pdo_sqlsrv \
&& apk del autoconf make g++ \
&& docker-run-bootstrap
# Копируем конфигурации
# Чистим pecl мусор
RUN rm -rf /usr/local/lib/php/test \
&& rm -rf /usr/local/lib/php/doc \
&& rm -rf /tmp/pear \
&& rm -rf /usr/src/php \
&& rm -f /usr/src/php.tar.xz 2>/dev/null || true
# Фикс OpenSSL 3 совместимости с SQL Server 2016
COPY docker/openssl.cnf /etc/ssl/openssl.cnf
COPY docker/nginx.conf /etc/nginx/nginx.conf
COPY docker/app.conf /etc/nginx/conf.d/default.conf
COPY docker/supervisord.conf /etc/supervisor/supervisord.conf
WORKDIR /var/www/html
# Копируем приложение из этапов сборки
COPY --chown=application:application --from=php-build /var/www/html .
COPY --chown=application:application --from=node-build /var/www/html/public/build ./public/build
# Настраиваем права
RUN chown -R application:application /var/www/html && \
chmod -R 775 /var/www/html/storage /var/www/html/bootstrap/cache
# Создаем символические ссылки
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