LaravelDocker

De InfoXelec
Aller à la navigation Aller à la recherche

Ecosystème

/home/user
        |_ dev_web
               |_ imgdocker : contient les éléments Docker
               |_ appname : contient l'application Laravel


Création de l'image Docker PHP7.4

Nous allons créer une image permettant de développer en PHP 7.4 et Laravel 6 sur un Ubuntu plus récent.
Il faut dans l'image php7.4, php7.4-mbstring, php7.4-mysql,...

Créer un dossier qui va héberger l'environnement de développement /home/user/dev_web/imgdocker Créer un fichier dockerfile-php74 avec les éléments suivants :

FROM ubuntu:focal
LABEL version=v1.2
ARG DEBIAN_FRONTEND=noninteractive
ARG APP_USER=jeff
ENV TZ=UTC
RUN apt-get update && apt-get install -y tzdata && \
    ln -fs /usr/share/zoneinfo/$TZ /etc/localtime && \
    dpkg-reconfigure --frontend noninteractive tzdata
RUN apt-get update && \
    apt-get install -y apache2 php7.4 libapache2-mod-php7.4 php7.4-cli php7.4-mbstring php7.4-xml php7.4-zip php7.4-curl php7.4-mysql
RUN php -r "copy('https://getcomposer.org/installer', 'composer-setup.php');" && \
    php composer-setup.php --install-dir=/usr/local/bin --filename=composer
# Create a dedicated user
RUN useradd --shell /bin/bash ${APP_USER}
#Switch to the new user
#USER ${APP_USER}:${APP_USER}
COPY --chown=${APP_USER} 000-default.conf /etc/apache2/sites-available/000-default.conf
RUN a2enmod rewrite
EXPOSE 80
CMD ["apache2ctl", "-D", "FOREGROUND"]

Où 000-default.conf est le fichier de configuration du serveur Apache.

<VirtualHost *:80>
	ServerName localhost

	ServerAdmin webmaster@localhost
	DocumentRoot /var/www/html/app/public
	<Directory /var/www/html/app/public>
		Options Indexes FollowSymLinks MultiViews
		AllowOverride All
		Order allow,deny
		allow from all
		Require all granted	
	</Directory>
	ErrorLog ${APACHE_LOG_DIR}/error.log
	CustomLog ${APACHE_LOG_DIR}/access.log combined
</VirtualHost>

Lancer la commande docker build -t ifxphp74:v1.2 -f dockerfile-php74 .

Création du conteneur Docker

version: '3'
name: 'ifxwebdev74'
services:
    web:
        image: 'ifxphp74:v1.2'
        ports:
            - '80:80'
        networks:
            - ifxnetdev
        depends_on:
            - mariadb
        volumes:
            - '/home/user/dev_web/appname:/var/www/html/app'
        depends_on:
            - db
    db:
        image: 'mariadb:lts'
        restart: 'unless-stopped'
        ports:
            - '3306:3306'
        environment:
            MYSQL_ROOT_PASSWORD: 'sqlpass'
            MYSQL_ROOT_HOST: '%'
            MYSQL_DATABASE: 'dbname'
            MYSQL_USER: 'dbuser'
            MYSQL_PASSWORD: 'dbpass'
            MYSQL_ALLOW_EMPTY_PASSWORD: 'yes'
        volumes:
            - './mysql:/var/lib/mysql'
        networks:
            - ifxnetdev
        healthcheck:
            test:
                - CMD
                - mysqladmin
                - ping
                - '-pdbpass'
            retries: 3
            timeout: 5s
networks:
    ifxnetdev:
        driver: bridge
volumes:
    ifx-mariadb:
        driver: local

Créer le conteneur avec la commande docker compose -f php74-compose.yml create depuis le dossier imgdocker.
On peut lancer le conteneur avec la commande docker compose -f php74-compose.yml start.

Utilisation

Pour utiliser Laravel depuis les conteneurs Docker, il faut lancer les commandes normales depuis le conteneur associé.
Il faut commencer par créer la base de données et l'utilisateur.

Configuration du conteneur de base de données

Lorsque le conteneur est lancé, se connecter au conteneur db avec la commande docker exec -it nomapp-db-1 mariadb -u root -p
Créer la base de données et l'utilisateur de l'application. Voir l'aide sur MySQL. La création de la base de données se fait lors du lancement du conteneur.
Pour la réinitialiser, il suffit de supprimer le dossier mysql du PC hôte.
Si on veut utiliser un visualiseur de base de données comme DBeaver, il faut mettre

  • Server Host : localhost
  • port : 3306
  • user : dbuser
  • password : dbpass

Car dans la liste des utilisateurs du MariaDB, cet utilisateur est créé avec host % qui est le wildcard.

Configuration de Laravel sur le conteneur

Lorsque le conteneur est lancé, se connecter au conteneur web avec la commande docker exec -it nomapp-web-1 bash
Se déplacer dans le dossier /var/www/html et lancer les commandes de création du projet Laravel.

Node

Pour l'utilisation de TailwindCSS, la compilation se fait avec VITE.
L'environnement de développement Node.JS (node, npm, nvm) doivent être installés sur la machine de développement.
La commande npm run dev qui permet la compilation automatique du JS doit être lancée depuis la machine de développement.