deactivated legacy, updated php to 8.1, misc

This commit is contained in:
Bachir Soussi Chiadmi 2025-03-21 15:31:18 +01:00
parent 70f5e01793
commit 43fd5dae4b
8 changed files with 194 additions and 81 deletions

3
.gitignore vendored
View File

@ -5,4 +5,7 @@ log/*
*.sql *.sql
bin/syncfiles.sh bin/syncfiles.sh
solr_cores/* solr_cores/*
solr_data/*
var_solr/*
ressources/xdebug.ini ressources/xdebug.ini
ressources/*.sql.gz

View File

@ -6,9 +6,9 @@ server {
charset utf-8; charset utf-8;
location / { # location / {
try_files $uri $uri/ /index.php?$query_string; # try_files $uri $uri/ /index.php?$query_string;
} # }
location = /favicon.ico { access_log off; log_not_found off; } location = /favicon.ico { access_log off; log_not_found off; }
location = /robots.txt { access_log off; log_not_found off; } location = /robots.txt { access_log off; log_not_found off; }
@ -20,18 +20,95 @@ server {
client_max_body_size 100m; client_max_body_size 100m;
location ~ \.php$ {
fastcgi_split_path_info ^(.+\.php)(/.+)$; # Very rarely should these ever be accessed outside of your lan
fastcgi_pass php:9000; location ~* \.(txt|log)$ {
fastcgi_index index.php; allow 192.168.0.0/16;
deny all;
}
location ~ \..*/.*\.php$ {
return 403;
}
location ~ ^/sites/.*/private/ {
return 403;
}
# Allow "Well-Known URIs" as per RFC 5785
location ~* ^/.well-known/ {
allow all;
}
# Block access to "hidden" files and directories whose names begin with a
# period. This includes directories used by version control systems such
# as Subversion or Git to store control files.
location ~ (^|/)\. {
return 403;
}
location / {
# try_files $uri @rewrite; # For Drupal <= 6
try_files $uri /index.php?$query_string; # For Drupal >= 7
}
location @rewrite {
rewrite ^/(.*)$ /index.php?q=$1;
}
# Don't allow direct access to PHP files in the vendor directory.
location ~ /vendor/.*\.php$ {
deny all;
return 404;
}
# In Drupal 10, we must also match new paths where the '.php' appears in
# the middle, such as update.php/selection. The rule we use is strict,
# and only allows this pattern with the update.php front controller.
# This allows legacy path aliases in the form of
# blog/index.php/legacy-path to continue to route to Drupal nodes. If
# you do not have any paths like that, then you might prefer to use a
# laxer rule, such as:
# location ~ \.php(/|$) {
# The laxer rule will continue to work if Drupal uses this new URL
# pattern with front controllers other than update.php in a future
# release.
location ~ '\.php$|^/update.php' {
fastcgi_split_path_info ^(.+?\.php)(|/.*)$;
# Security note: If you're running a version of PHP older than the
# latest 5.3, you should have "cgi.fix_pathinfo = 0;" in php.ini.
# See http://serverfault.com/q/627903/94922 for details.
include fastcgi_params; include fastcgi_params;
# Block httpoxy attacks. See https://httpoxy.org/.
fastcgi_param HTTP_PROXY "";
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
fastcgi_intercept_errors off; fastcgi_param PATH_INFO $fastcgi_path_info;
fastcgi_param QUERY_STRING $query_string;
fastcgi_intercept_errors on;
fastcgi_buffer_size 16k; fastcgi_buffer_size 16k;
fastcgi_buffers 4 16k; fastcgi_buffers 4 16k;
fastcgi_read_timeout 150; fastcgi_read_timeout 150;
# PHP 5 socket location.
#fastcgi_pass unix:/var/run/php5-fpm.sock;
# PHP 7 socket location.
#fastcgi_pass unix:/var/run/php/php7.0-fpm.sock;
#lando
fastcgi_pass php:9000;
} }
# location ~ \.php$ {
# fastcgi_split_path_info ^(.+\.php)(/.+)$;
# fastcgi_pass php:9000;
# fastcgi_index index.php;
# include fastcgi_params;
# fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
# fastcgi_intercept_errors off;
# fastcgi_buffer_size 16k;
# fastcgi_buffers 4 16k;
# fastcgi_read_timeout 150;
# }
location ~ /\.ht { location ~ /\.ht {
deny all; deny all;
} }
@ -42,11 +119,29 @@ server {
gzip_http_version 1.0; gzip_http_version 1.0;
gzip_static on; gzip_static on;
# Fighting with Styles? This little gem is amazing.
# location ~ ^/sites/.*/files/imagecache/ { # For Drupal <= 6
location ~ ^(/[a-z\-]+)?/sites/.*/files/(css|js|styles)/ { # For Drupal >= 7
try_files $uri @rewrite;
}
# Handle private files through Drupal. Private file's path can come
# with a language prefix.
location ~ ^(/[a-z\-]+)?/system/files/ { # For Drupal >= 7
try_files $uri /index.php?$query_string;
}
location ~* \.(js|css|png|jpg|jpeg|gif|ico)$ {
expires max;
log_not_found off;
}
## PWA serviceworker support. ## PWA serviceworker support.
# location ~ ^/pwa/[0-9a-z]+/serviceworker.js { # location ~ ^/pwa/[0-9a-z]+/serviceworker.js {
# try_files $uri /index.php?$query_string; # try_files $uri /index.php?$query_string;
# } # }
## PWA manifest support. ## PWA manifest support.
location ~ /manifest.json { location ~ /manifest.json {
try_files $uri /index.php?$query_string; try_files $uri /index.php?$query_string;
@ -55,5 +150,7 @@ server {
location ~* \.(js|css|ttf|json)$ { location ~* \.(js|css|ttf|json)$ {
gzip_static on; gzip_static on;
} }
} }

View File

@ -1,4 +1,4 @@
FROM php:7.4-fpm FROM php:8.1-fpm-bullseye
RUN apt-get update && apt-get install -y \ RUN apt-get update && apt-get install -y \
libfreetype6-dev \ libfreetype6-dev \
@ -19,7 +19,7 @@ RUN apt-get update && apt-get install -y \
docker-php-ext-install opcache && \ docker-php-ext-install opcache && \
docker-php-ext-install bcmath && \ docker-php-ext-install bcmath && \
apt-get install -y git vim && \ apt-get install -y git vim && \
pecl install redis-4.3.0 && \ pecl install redis-5.3.7 && \
pecl install xdebug-3.1.3 && \ pecl install xdebug-3.1.3 && \
docker-php-ext-enable redis xdebug docker-php-ext-enable redis xdebug
@ -69,6 +69,10 @@ RUN if getent group ${USER_GNAME} ; then groupdel ${USER_GNAME}; fi &&\
COPY ./bashrc /home/${USER_UNAME}/.bashrc COPY ./bashrc /home/${USER_UNAME}/.bashrc
COPY ./inputrc /home/${USER_UNAME}/.inputrc COPY ./inputrc /home/${USER_UNAME}/.inputrc
# https://github.com/ProgDroid/composer_update_autocomplete
RUN mkdir /home/${USER_UNAME}/.bin
COPY ./composer_update_autocomplete /home/${USER_UNAME}/.bin/composer_update_autocomplete
RUN printf "complete -C /home/${USER_UNAME}/.composer_update_autocomplete/src/main.rs composer update" >> /home/${USER_UNAME}/.bashrc
# https://dev.to/s1ntaxe770r/how-to-setup-ssh-within-a-docker-container-i5i # https://dev.to/s1ntaxe770r/how-to-setup-ssh-within-a-docker-container-i5i
RUN apt-get install -y openssh-server openssh-client RUN apt-get install -y openssh-server openssh-client

Binary file not shown.

View File

@ -41,6 +41,12 @@ buildnpm:
buildnpmnc: buildnpmnc:
docker-compose build --no-cache --build-arg USER_UID=$(USER_UID) --build-arg USER_UNAME=$(USER_UNAME) --build-arg USER_GID=$(USER_GID) --build-arg USER_GNAME=$(USER_GNAME) npm docker-compose build --no-cache --build-arg USER_UID=$(USER_UID) --build-arg USER_UNAME=$(USER_UNAME) --build-arg USER_GID=$(USER_GID) --build-arg USER_GNAME=$(USER_GNAME) npm
buildmysql:
docker-compose build --build-arg USER_UID=$(USER_UID) --build-arg USER_UNAME=$(USER_UNAME) --build-arg USER_GID=$(USER_GID) --build-arg USER_GNAME=$(USER_GNAME) mysql
buildmysqlnc:
docker-compose build --no-cache --build-arg USER_UID=$(USER_UID) --build-arg USER_UNAME=$(USER_UNAME) --build-arg USER_GID=$(USER_GID) --build-arg USER_GNAME=$(USER_GNAME) mysql
up: up:
docker-compose up -d docker-compose up -d
@ -72,6 +78,9 @@ restart_php:
restart_npm : restart_npm :
docker-compose restart npm docker-compose restart npm
restart_mysql :
docker-compose restart mysql
exec_php: exec_php:
docker exec -it materiod8-php-1 bash docker exec -it materiod8-php-1 bash

View File

@ -17,21 +17,21 @@ services:
MYSQL_USER: "${DB_USERNAME}" MYSQL_USER: "${DB_USERNAME}"
MYSQL_PASSWORD: "${DB_PASSWORD}" MYSQL_PASSWORD: "${DB_PASSWORD}"
mysql-legacy: # mysql-legacy:
image: mariadb:latest # image: mariadb:latest
volumes: # volumes:
- db-data-legacy:/var/lib/mysql # - db-data-legacy:/var/lib/mysql
- ./Docker/mysql/mysql.cnf:/etc/mysql/conf.d/custom.cnf:ro # - ./Docker/mysql/mysql.cnf:/etc/mysql/conf.d/custom.cnf:ro
- ./Docker/mysql/bashrc:/root/.bashrc:ro # - ./Docker/mysql/bashrc:/root/.bashrc:ro
- "${DB_IMPORTE_FILE_D7}:/docker-entrypoint-initdb.d/materio_d7.sql" # - "${DB_IMPORTE_FILE_D7}:/docker-entrypoint-initdb.d/materio_d7.sql"
networks: # networks:
- database # - database
hostname: mysql-legacy # hostname: mysql-legacy
environment: # environment:
MYSQL_ROOT_PASSWORD: "${DB_ROOT_PASSWORD}" # MYSQL_ROOT_PASSWORD: "${DB_ROOT_PASSWORD}"
MYSQL_DATABASE: "${DB_LEGACY_NAME}" # MYSQL_DATABASE: "${DB_LEGACY_NAME}"
MYSQL_USER: "${DB_USERNAME}" # MYSQL_USER: "${DB_USERNAME}"
MYSQL_PASSWORD: "${DB_PASSWORD}" # MYSQL_PASSWORD: "${DB_PASSWORD}"
redis: redis:
image: redis:4 image: redis:4
@ -44,16 +44,16 @@ services:
ports: ports:
- "6389" - "6389"
redis-legacy: # redis-legacy:
image: redis:3 # image: redis:3
command: redis-server /usr/local/etc/redis.conf # command: redis-server /usr/local/etc/redis.conf
volumes: # volumes:
- redis-legacy-data:/data # - redis-legacy-data:/data
- ./Docker/redis/redis.conf:/usr/local/etc/redis.conf # - ./Docker/redis/redis.conf:/usr/local/etc/redis.conf
networks: # networks:
- redis # - redis
ports: # ports:
- "6388" # - "6388"
solr-new: solr-new:
build: ./Docker/solr/ build: ./Docker/solr/
@ -73,14 +73,14 @@ services:
ports: ports:
- 8985:8983 - 8985:8983
solr-legacy: # solr-legacy:
build: ./Docker/solr-legacy/ # build: ./Docker/solr-legacy/
volumes: # volumes:
- solr-cores-legacy:/opt/solr/server/solr # - solr-cores-legacy:/opt/solr/server/solr
networks: # networks:
- solr # - solr
ports: # ports:
- 8983:8983 # - 8983:8983
php: php:
@ -109,28 +109,28 @@ services:
# mem_limit: 512m # mem_limit: 512m
depends_on: depends_on:
- mysql - mysql
- mysql-legacy # - mysql-legacy
- redis - redis
- solr-new - solr-new
php-legacy: # php-legacy:
build: ./Docker/php-legacy/ # build: ./Docker/php-legacy/
expose: # expose:
- 9000 # - 9000
volumes: # volumes:
- php-legacy-root-data:/root # - php-legacy-root-data:/root
- "${LEGACY_ROOT}:/var/www/html" # - "${LEGACY_ROOT}:/var/www/html"
- "${LOG_ROOT}/php-legacy:/var/log:rw" # - "${LOG_ROOT}/php-legacy:/var/log:rw"
working_dir: "/var/www/html" # working_dir: "/var/www/html"
networks: # networks:
- database # - database
- redis # - redis
- server # - server
- solr # - solr
depends_on: # depends_on:
- mysql-legacy # - mysql-legacy
- redis-legacy # - redis-legacy
- solr-legacy # - solr-legacy
phpmyadmin: phpmyadmin:
image: phpmyadmin/phpmyadmin image: phpmyadmin/phpmyadmin
@ -140,9 +140,9 @@ services:
- database - database
depends_on: depends_on:
- mysql - mysql
- mysql-legacy # - mysql-legacy
environment: environment:
PMA_HOSTS: mysql,mysql-legacy PMA_HOSTS: mysql #,mysql-legacy
nginx: nginx:
build: ./Docker/nginx/ build: ./Docker/nginx/
@ -150,7 +150,7 @@ services:
- 8890:80 - 8890:80
volumes: volumes:
- "${PROJECT_ROOT}:/var/www/html/d8.materio.com/public_html" - "${PROJECT_ROOT}:/var/www/html/d8.materio.com/public_html"
- "${LEGACY_ROOT}:/var/www/html/d7.materio.com/public_html" # - "${LEGACY_ROOT}:/var/www/html/d7.materio.com/public_html"
- "${LOG_ROOT}:/var/log:rw" - "${LOG_ROOT}:/var/log:rw"
working_dir: "/var/www/html/d8.materio.com/public_html" working_dir: "/var/www/html/d8.materio.com/public_html"
networks: networks:
@ -159,18 +159,18 @@ services:
depends_on: depends_on:
- php - php
nginx-legacy: # nginx-legacy:
build: ./Docker/nginx-legacy/ # build: ./Docker/nginx-legacy/
ports: # ports:
- 8880:80 # - 8880:80
volumes: # volumes:
- "${LEGACY_ROOT}:/var/www/html" # - "${LEGACY_ROOT}:/var/www/html"
- "${LOG_ROOT}:/var/log:rw" # - "${LOG_ROOT}:/var/log:rw"
networks: # networks:
- server # - server
- solr # - solr
depends_on: # depends_on:
- php-legacy # - php-legacy
npm: npm:
build: ./Docker/npm build: ./Docker/npm
@ -189,12 +189,12 @@ services:
volumes: volumes:
php-user-data: php-user-data:
php-legacy-root-data: # php-legacy-root-data:
db-data: db-data:
db-data-legacy: # db-data-legacy:
redis-data: redis-data:
redis-legacy-data: # redis-legacy-data:
solr-cores-legacy: # solr-cores-legacy:
# solr-cores: # solr-cores:
npm-user-data: npm-user-data:

0
solr_data/.gitkeep Normal file
View File

0
var_solr/.gitkeep Normal file
View File