# Popsu Docker Popsu powered by druapl 7 in docker environement (nginx, php:5.6-fpm+drush, mariadb, redis:4, phpmyadmin) ## Install docker ``` sudo pacman -S docker docker-compose docker-machine ``` art the docker service ``` sudo systemctl start docker ``` For all the following, DO NOT run docker or make commande as root or with sudo, use this setup: add your user to the docker user group, re-login, and restart docker.service. https://wiki.archlinux.org/index.php/Docker#Installation ## Clone this repos this will clone this repos (main docker environement) and the popsu.arch.fr drupal 7 & 9 source code (without sites/default folder nor mysq ddbs) ``` git clone --recursive -o figli https://figureslibres.io/gogs/bachir/docker-popsu.git ``` submodules : - https://figureslibres.io/gogs/bachir/popsu-d7 - https://figureslibres.io/gogs/bachir/popsu-d9 ### setup /sites/default/settings.php ``` cp -r ressources/d7/settings.php src_d7/sites/default/ cp -r ressources/d9/settings.php src_d9/web/sites/default/ cp -r ressources/d9/settings.local.php src_d9/web/sites/default/ ``` ### get the sites/default/files folder rsync the files from you know where (if you don't, you don't) to src_d7/sites/default/files/ and src_d9/web/sites/default/files/ ### xdebug copy ```ressources/xdebug.ini.exemple``` to ```ressources/xdebug.ini``` and edit the ```xdebug.remote_host``` ip to your host locale ip (e.g. : 192.168.0.23) (or once the docker is started to the host ip from the container point of vu e.g. 172.21.0.1) ## Mysql Copy your-sql-dump.sql files into ```./ressources/popsu_d7.sql``` and ```./ressources/popsu_d9.sql``` They will be automaticly imported into the mysql containers dbs (only) on the first docker-compose up ## Hosts and reverse proxy add to your /etc/hosts : ``` 127.0.0.1 dev.d7.popsu.archi.fr 127.0.0.1 dev.d9.popsu.archi.fr 127.0.0.1 dev.phpmyadmin.popsu.archi.fr ``` configure your vhosts to add a reverse proxy that will redirect the dev.materio.com to our container ### nginx ```sh sudo mkdir /etc/var/log/popsu ``` ```nginx server { listen 80; server_name dev.d7.popsu.archi.fr dev.d9.popsu.archi.fr; access_log off; error_log /var/log/nginx/popsu/error.log error; client_max_body_size 100m; location / { proxy_pass http://127.0.0.1:8980; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header X-Forwarded-Proto $scheme; proxy_buffer_size 128k; proxy_buffers 4 256k; proxy_busy_buffers_size 256k; } } server { listen 80; server_name dev.phpmyadmin.popsu.archi.fr; location / { proxy_pass http://127.0.0.1:8981; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header X-Forwarded-Proto $scheme; proxy_buffer_size 128k; proxy_buffers 4 256k; proxy_busy_buffers_size 256k; } } ``` ### apache ```apache ServerName dev.d7.popsu.archi.fr ProxyPass / http://127.0.0.1:8980/ ProxyPassReverse / http://127.0.0.1:8980/ ProxyRequests Off ProxyPreserveHost On proxy_buffer_size 128k; proxy_buffers 4 256k; proxy_busy_buffers_size 256k; ServerName dev.d9.popsu.archi.fr ProxyPass / http://127.0.0.1:8980/ ProxyPassReverse / http://127.0.0.1:8980/ ProxyRequests Off ProxyPreserveHost On proxy_buffer_size 128k; proxy_buffers 4 256k; proxy_busy_buffers_size 256k; ServerName dev.phpmyadmin.popsu.archi.fr ProxyPass / http://127.0.0.1:8981/ ProxyPassReverse / http://127.0.0.1:8981/ ProxyRequests Off ProxyPreserveHost On proxy_buffer_size 128k; proxy_buffers 4 256k; proxy_busy_buffers_size 256k; ``` ## Docker For all the following, DO NOT run docker or make commande as root or with sudo, use your regular user but first add your user to the docker user group, re-login, and restart docker.service. ```sh usermod -aG docker yourusername # https://wiki.archlinux.org/title/Docker#Installation restart ``` ### docker-compose pull pull the latest image of services ```sh make pull ``` ### build only before the first run (may take some time) /!\ DO NOT use ```docker-compose build```, it will fail (check Makefile for more info) ```sh make build ``` ### run then each time you want to launch the app ```sh make up ``` Be aware that a first up, since the db is empty, it will be populated with your files ressources/db_d7.sql and ressources/db_d9.sql. It may take some time depending of your db size. ## Drupal Composer install Only at first up, finish to install drupal 9 composer dependencies ```sh make exec_php_d9 composer install # or juste make d9_composer_install ``` ## Visualize You can now visit http://dev.d7.popsu.archi.fr and http://dev.d9.popsu.archi.fr on your browser After the first run ## Coding ### drush you can access to drush by loging into the php container ```sh make exec_php_d7 # or make exec_php_d9 ``` once inside the php container in /var/www/html you can use drush as usual ## Updating code ```sh git pull figli master # then update all submodules git submodule update --recursive --checkout # or only d7 git submodule update --checkout src_d7/ # or only d9 git submodule update --checkout src_d9/ # if you updated d9 code then run make d9_maj_config ``` ## Updating manualy the mysql db copy your db backup into the mysql container ```sh docker cp your-db-file.sql popsu_mysql_d7_1:/root/ # or docker cp your-db-file.sql popsu_mysql_d9_1:/root/ ``` log into mysql container ```sh make exec_mysql_d7 # or make exec_mysql_d9 ``` once inside the mysql container you can use mysql command to drop then create and load the db with your file ``` mysql -uroot -ppopsu > drop database popsu_d7; > create database popsu_d7; > exit; mysql -uroot -ppopsu popsu_d7 < your-db-file.sql # or mysql -uroot -ppopsu > drop database popsu_d9; > create database popsu_d9; > exit; mysql -uroot -ppopsu popsu_d9 < your-db-file.sql ``` ## Makefile DO NOT use directly docker or docker-compose to run this instance use make instead like ```make up``` ```makefile #!/usr/bin/make SHELL = /bin/sh USER_UID := $(shell id -u) USER_UNAME := $(shell id -un) USER_GID := $(shell id -g) USER_GNAME := $(shell id -gn) export USER_UID export USER_UNAME export USER_GID export USER_GNAME pull: docker-compose pull build: 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) buildnc: 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) downbuildup: down build up up: docker-compose up -d ps: docker-compose ps logs: docker-compose logs -f d9_maj_config: d9_crd d9_composer_install d9_updb d9_cim d9_cr d9_crd: docker exec enfrancais_pgp_d9_1 /bin/bash -c "drush cache-clear drush" d9_cr: docker exec enfrancais_pgp_d9_1 /bin/bash -c "drush cr" d9_updb: docker exec enfrancais_pgp_d9_1 /bin/bash -c "drush updb -y" d9_cim: docker exec enfrancais_pgp_d9_1 /bin/bash -c "drush config-import -y" d9_composer_install: docker exec enfrancais_pgp_d9_1 /bin/bash -c "composer install --no-dev" down: docker-compose down exec_php_d7: docker exec -it popsu_php_d7_1 bash exec_php_d9: docker exec -it popsu_php_d9_1 sh exec_mysql_d7: docker exec -it popsu_mysql_d7 bash exec_mysql_d9: docker exec -it popsu_mysql_d9 bash ```