Switch from nginx to Apache

So I can use a .htaccess file for wildcard redirects.
This commit is contained in:
Oliver Davies 2024-04-04 19:11:33 +01:00
parent 19c77678fb
commit 29c2d595ae
6 changed files with 22 additions and 51 deletions

View file

@ -5,7 +5,7 @@ export DOCKER_UID=1000
export COMPOSE_PROJECT_NAME=oliverdavies-uk export COMPOSE_PROJECT_NAME=oliverdavies-uk
export COMPOSE_PROFILES=web,php,database export COMPOSE_PROFILES=web,php,database
export DOCKER_WEB_VOLUME=.:/app export DOCKER_WEB_VOLUME=.:/var/www/html
export MYSQL_DATABASE=app export MYSQL_DATABASE=app
export MYSQL_PASSWORD=app export MYSQL_PASSWORD=app

View file

@ -1,6 +1,6 @@
# Do not edit this file. It is automatically generated by https://www.oliverdavies.uk/build-configs. # Do not edit this file. It is automatically generated by https://www.oliverdavies.uk/build-configs.
FROM php:8.2-fpm-bullseye AS base FROM php:8.2-apache AS base
COPY --from=composer:2 /usr/bin/composer /usr/bin/composer COPY --from=composer:2 /usr/bin/composer /usr/bin/composer
RUN which composer && composer -V RUN which composer && composer -V
@ -8,14 +8,14 @@ RUN which composer && composer -V
ARG DOCKER_UID=1000 ARG DOCKER_UID=1000
ENV DOCKER_UID="${DOCKER_UID}" ENV DOCKER_UID="${DOCKER_UID}"
WORKDIR /app WORKDIR /var/www/html
RUN adduser --disabled-password --uid "${DOCKER_UID}" app \ RUN adduser --disabled-password --uid "${DOCKER_UID}" app \
&& chown app:app -R /app && chown app:app -R /var/www/html
USER app USER app
ENV PATH="${PATH}:/app/bin:/app/vendor/bin" ENV PATH="${PATH}:/var/www/html/bin:/var/www/html/vendor/bin"
COPY --chown=app:app composer.* ./ COPY --chown=app:app composer.* ./
@ -25,6 +25,7 @@ FROM base AS build
USER root USER root
RUN a2enmod rewrite
RUN apt-get update -yqq \ RUN apt-get update -yqq \
&& apt-get install -yqq --no-install-recommends \ && apt-get install -yqq --no-install-recommends \
@ -48,17 +49,8 @@ RUN composer install --quiet --no-progress
COPY --chown=app:app tools/docker/images/php/root / COPY --chown=app:app tools/docker/images/php/root /
ENTRYPOINT ["/usr/local/bin/docker-entrypoint-php"] ENTRYPOINT ["/usr/local/bin/docker-entrypoint-php"]
CMD ["php-fpm"] CMD ["apache2-foreground"]
################################################################################
FROM nginx:1 as web
EXPOSE 8080
WORKDIR /app
COPY tools/docker/images/web/root /

View file

@ -2,8 +2,10 @@ name: oliverdavies-uk
type: drupal type: drupal
language: php language: php
project_root: /var/www/html
web: web:
type: nginx type: apache
database: database:
type: mariadb type: mariadb
@ -11,7 +13,7 @@ database:
extra_databases: [] extra_databases: []
php: php:
version: 8.2-fpm-bullseye version: 8.2-apache
phpcs: phpcs:
paths: paths:
- web/modules/custom - web/modules/custom
@ -29,7 +31,6 @@ docker-compose:
services: services:
- database - database
- php - php
- web
dockerfile: dockerfile:
stages: stages:

View file

@ -12,7 +12,7 @@ x-proxy: &default-proxy
x-app: &default-app x-app: &default-app
volumes: volumes:
- "${DOCKER_WEB_VOLUME:-./web:/app/web}" - "${DOCKER_WEB_VOLUME:-./web:/var/www/html/web}"
env_file: env_file:
- .env - .env
restart: "${DOCKER_RESTART_POLICY:-unless-stopped}" restart: "${DOCKER_RESTART_POLICY:-unless-stopped}"
@ -28,24 +28,16 @@ x-app: &default-app
tty: true tty: true
services: services:
web:
<<: [*default-proxy, *default-app]
build:
context: .
target: web
depends_on:
- php
profiles: [web]
php: php:
<<: [*default-app] <<: [*default-proxy, *default-app]
build: build:
context: . context: .
target: build target: build
args: args:
- "DOCKER_UID=${DOCKER_UID:-1000}" - "DOCKER_UID=${DOCKER_UID:-1000}"
volumes: volumes:
- .:/app - .:/var/www/html
depends_on: depends_on:
- database - database
profiles: [php] profiles: [php]

View file

@ -0,0 +1,8 @@
# Do not edit this file. It is automatically generated by https://www.oliverdavies.uk/build-configs.
<VirtualHost *:80>
DocumentRoot /var/www/html/web
ErrorLog ${APACHE_LOG_DIR}/error.log
CustomLog ${APACHE_LOG_DIR}/access.log combined
</VirtualHost>

View file

@ -1,22 +0,0 @@
# Do not edit this file. It is automatically generated by https://www.oliverdavies.uk/build-configs.
server {
server_name _;
root /app/web;
location / {
try_files $uri /index.php?$query_string;
}
location ~ \.php(/|$) {
fastcgi_split_path_info ^(.+?\.php)(|/.*)$;
try_files $fastcgi_script_name =404;
include fastcgi_params;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
fastcgi_param PATH_INFO $fastcgi_path_info;
fastcgi_param QUERY_STRING $query_string;
fastcgi_intercept_errors on;
fastcgi_pass php:9000;
}
}