popsu-colloque # Popsu Coloque 8.x Docker Environement Popsu Colloques powered by druapl in docker environement (nginx, php-fpm+drush, phpmyadmin, redis) ## 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 edlp drupal 8 source code (without sites/default folder) ``` git clone --recursive -o gogs https://figureslibres.io/gogs/bachir/docker-popsu-coloques.git ``` ## touch log file ```sh touch log/nginx/error.log ``` ### setup /sites/default/settings.php ```sh cp -r ressources/drupal/default/settings.php app/web/sites/default/ cp -r ressources/drupal/default/settings.local.php app/web/sites/default/ cp -r ressources/drupal/default/services.yml app/web/sites/default/ cp -r ressources/drupal/colloque2024.popsu.archi.fr/settings.php app/web/sites/colloque2024.popsu.archi.fr/ cp -r ressources/drupal/colloque2024.popsu.archi.fr/settings.local.php app/web/sites/colloque2024.popsu.archi.fr/ cp -r ressources/drupal/colloque2024.popsu.archi.fr/services.yml app/web/sites/colloque2024.popsu.archi.fr/ ``` ### get the sites/default/salt.txt file (if you don't have it, you don't) ### get the sites/default/files folder rsync the files from you know where (if you don't, you don't) to app/sites/default/files/ and app/sites/colloque2024.popsu.archi.fr/files/ ## Mysql Copy your-sql-dump.sql into ./ressources/popsucolloque21.sql & ./ressources/popsucolloque24.sql It will be automaticly imported into the mysql container db (only) on the first docker-compose up ## Hosts and reverse proxy add to your /etc/hosts : ``` #/etc/hosts 127.0.0.1 dev.colloque2021.popsu.archi.fr 127.0.0.1 dev.colloque2024.popsu.archi.fr 127.0.0.1 dev.phpmyadmin.popsucolloques.fr ``` configure your nginx vhosts to add a reverse proxy that will redirect the dev.colloque2021.popsu.archi.fr and dev.colloque2024.popsu.archi.fr to our container ```nginx server { listen 80; server_name dev.colloque2021.popsu.archi.fr dev.colloque2024.popsu.archi.fr; location / { proxy_pass http://127.0.0.1:8890; 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.popsucolloques.fr; location / { proxy_pass http://127.0.0.1:8891; 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; } } ``` ## 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 composer dependencies ```sh make exec_php composer install # or juste make composer_install ``` ## Visualize You can now visit http://dev.colloque2021.popsu.archi.fr & http://dev.colloque2024.popsu.archi.fr on your browser ## Coding ### drush you can access to drush by loging into the php container ```sh make exec_php ``` 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 # if you updated d9 code then run make maj_config ``` ## Updating manualy the mysql db copy your db backup into the mysql container ```sh docker cp your-db-file.sql popsucoloque-mysql-1:/root/ ``` log into mysql container ```sh make exec_mysql ``` once inside the mysql container you can use mysql command to drop then create and load the db with your file ``` mysql -uroot -popsu > drop database colloque21; > create database colloque21; > exit; mysql -uroot -ppopsu colloque21 < your-db-file-name.sql ``` or ``` mysql -uroot -popsu > drop database colloque24; > create database colloque24; > exit; mysql -uroot -ppopsu colloque24 < your-db-file-name.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 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) up: docker-compose up -d upbuild: docker-compose up -d --build ps: docker-compose ps logs: docker-compose logs -f down: docker-compose down maj_config: crd composer_install updb cim cr crd: docker exec popsucoloque-php-1 /bin/bash -c "vendor/bin/drush cache-clear drush" composer_install: docker exec popsucoloque-php-1 /bin/bash -c "composer install --no-dev" updb: docker exec popsucoloque-php-1 /bin/bash -c "vendor/bin/drush updb -y" cim: docker exec popsucoloque-php-1 /bin/bash -c "vendor/bin/drush config-import -y" cr: docker exec q2d-php-1 /bin/bash -c "vendor/bin/drush cr" exec_php: docker exec -it popsucoloque-php-1 bash exec_nginx: docker exec -it popsucoloque-nginx-1 bash exec_mysql: docker exec -it popsucoloque-mysql-1 bash restart_php: docker-compose restart php restart_nginx: docker-compose restart nginx dump_db: docker exec popsucoloque-mysql-1 sh -c 'exec mysqldump -uroot -ppopsu colloque21' > ./ressources/colloque21-$(DATE_NOW)-local.sql docker exec popsucoloque-mysql-1 sh -c 'exec mysqldump -uroot -ppopsu colloque24' > ./ressources/colloque24-$(DATE_NOW)-local.sql ``` # sources https://www.ostraining.com/blog/drupal/docker/ http://tech.osteel.me/posts/2017/01/15/how-to-use-docker-for-local-web-development-an-update.html https://mmenozzi.github.io/2016/01/22/php-web-development-with-docker/ https://dzone.com/articles/continuous-drupal-maintaining-a-drupal-website-wit// https://github.com/glaux/drupal8docker https://www.jeffgeerling.com/blogs/jeff-geerling/drupal-8-redis-php-7-nginx-and https://chromatichq.com/blog/configuring-redis-caching-drupal-8