Si vous utilisez une image mysql, mariadb (ou dérivée comme wodby/mariadb de la suite docker4drupal) alors vous savez que par défaut une seule base de données est initialisée lors de la création du conteneur. Il est possible d'en créer autant que l'on veut via les script d'initialisation.
En voici un exemple qui va en créer deux, et en affecter le plein contrôle à l'utilisateur mysql drupal :
CREATE DATABASE IF NOT EXISTS `mabase1`;
CREATE DATABASE IF NOT EXISTS `mabase2`;
GRANT ALL PRIVILEGES ON mabase1.* TO 'drupal'@'%';
GRANT ALL PRIVILEGES ON mabase2.* TO 'drupal'@'%';
Pour que ce script se lance automatiquement à la création du conteneur nous allons l'ajouter au point de montage du dossier /docker-entrypoint-initdb.d dans le conteneur.
Sur notre machine nous allons placer le script dans le dossier ./files/databases/provisioning/init.sql et nous modifions en conséquence notre fichier docker-compose.yml :
mariadb:
image: wodby/mariadb:$MARIADB_TAG
container_name: "${PROJECT_NAME}_mariadb"
stop_grace_period: 30s
volumes:
- ./files/databases/provisioning:/docker-entrypoint-initdb.d
Les bases seront ainsi créées automatiquement au lancement du conteneur !
Contenus en rapport
J'utilise maintenant docker-compose pour l'ensemble de mes projets, principalement avec la formidable pile « docker4drupal ».
En ayant marre d'avoir à gérer x versions de de NodeJS sur ma machine avec pour chacune ses dépendances et incompatibilités, et de devoir se souvenir pour chaque projet quelle version utiliser, j'ai fini par externaliser cette gestion à docker, comme je le fais déjà depuis longtemps pour php, mysql, SolR...
Je ne m'occupe pas du développement front, mais il m'arrive d'avoir à réaliser une modification rapide de CSS ou JS sur un projet qui peut avoir parfois quelques années, (une éternité dans l'écosystème javascript).
Phpcs (ou PHP Code Sniffer) est un inspecteur de code permettant de vérifier la validité du code écrits en fonction de standards.
Pour l'ajouter à notre projet drupal géré via composer :
Ajouter un commentaire