# Deploiement Docker — Inventory ## Pre-requis ### Docker ```bash # Ubuntu sudo apt update sudo apt install -y ca-certificates curl gnupg sudo install -m 0755 -d /etc/apt/keyrings curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo gpg --dearmor -o /etc/apt/keyrings/docker.gpg echo "deb [arch=$(dpkg --print-architecture) signed-by=/etc/apt/keyrings/docker.gpg] https://download.docker.com/linux/ubuntu $(. /etc/os-release && echo "$VERSION_CODENAME") stable" | sudo tee /etc/apt/sources.list.d/docker.list > /dev/null sudo apt update sudo apt install -y docker-ce docker-ce-cli containerd.io docker-compose-plugin sudo usermod -aG docker $USER ``` Se deconnecter/reconnecter pour que le groupe `docker` prenne effet. ### Nginx ```bash sudo apt install -y nginx sudo systemctl enable nginx sudo systemctl start nginx ``` ### PostgreSQL PostgreSQL tourne dans un conteneur Docker separe (voir le repo `infra-postgres`). Il doit etre installe et accessible avant de deployer Inventory. Creer la base de donnees pour Inventory : ```bash cd /var/www/postgres docker compose exec postgres psql -U admin ``` ```sql -- Si le user n'existe pas encore CREATE USER malio WITH PASSWORD 'motdepasse'; -- Creer la base CREATE DATABASE inventory_prod OWNER malio; \q ``` --- ## Premiere installation (nouvelle machine) Guide complet pour mettre en ligne Inventory sur une machine vierge. Inclut les pre-requis, la BDD et l'app. ### 1. Installer les pre-requis Installer Docker, Nginx et PostgreSQL (voir section Pre-requis ci-dessus). ### 2. Creer le dossier de deploiement ```bash sudo mkdir -p /var/www/inventory sudo chown -R $(whoami):$(whoami) /var/www/inventory cd /var/www/inventory ``` ### 3. Se connecter au registry Docker de Gitea ```bash docker login gitea.malio.fr ``` - **Username** : le nom d'utilisateur du compte organisation Gitea `MALIO` - **Password** : le token REGISTRY_TOKEN dispo dans le bitwarden Le login est sauvegarde dans `~/.docker/config.json`, pas besoin de le refaire a chaque deploiement. ### 4. Creer les fichiers de deploiement Creer `docker-compose.yml` : ```yaml services: app: image: gitea.malio.fr/malio-dev/inventory:${INVENTORY_IMAGE_TAG:-latest} container_name: inventory-app env_file: .env ports: - "8080:80" volumes: - ./uploads:/var/www/html/var/uploads extra_hosts: - "host.docker.internal:host-gateway" restart: unless-stopped ``` Creer `deploy.sh` : ```bash #!/usr/bin/env bash set -euo pipefail cd "$(dirname "$0")" TAG="${1:-latest}" export INVENTORY_IMAGE_TAG="$TAG" echo "==> Deploying inventory:${TAG}..." echo "==> Pulling image..." docker compose pull echo "==> Starting container..." docker compose up -d echo "==> Waiting for container to be ready..." sleep 3 echo "==> Running migrations..." docker compose exec -T -u www-data app php bin/console doctrine:migrations:migrate --no-interaction echo "==> Clearing cache..." docker compose exec -T -u www-data app php bin/console cache:clear --env=prod docker compose exec -T -u www-data app php bin/console cache:warmup --env=prod VERSION=$(docker compose exec -T app cat VERSION) echo "==> Deployed v${VERSION}" ``` Rendre executable : ```bash chmod +x deploy.sh ``` ### 5. Configurer l'environnement Creer `.env` avec les variables suivantes : ```env # Symfony APP_ENV=prod APP_DEBUG=0 APP_SECRET= # Database (host.docker.internal = la machine hote, ou le PG tourne en Docker) DATABASE_URL="postgresql://malio:password@host.docker.internal:5432/inventory_prod?serverVersion=16&charset=utf8" # CORS CORS_ALLOW_ORIGIN='^https?://inventory\.malio-dev\.fr$' ``` ### 6. Creer le dossier uploads ```bash mkdir -p uploads ``` ### 7. Configurer Nginx systeme Creer `/etc/nginx/sites-available/inventory.conf` : ```nginx server { listen 80; server_name inventory.malio-dev.fr; location / { proxy_pass http://127.0.0.1:8080; 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; } } ``` Activer le site : ```bash sudo ln -sf /etc/nginx/sites-available/inventory.conf /etc/nginx/sites-enabled/inventory.conf sudo nginx -t && sudo systemctl reload nginx ``` ### 8. Deployer ```bash ./deploy.sh ``` ### 9. Importer les donnees (optionnel) Si tu as un dump SQL a importer : ```bash # Depuis ton PC, envoyer le dump vers le serveur scp inventory.sql user@serveur:/tmp/inventory.sql # Sur le serveur, vider la base puis importer cd /var/www/postgres docker compose exec -T postgres psql -U malio inventory_prod -c "DROP SCHEMA public CASCADE; CREATE SCHEMA public;" docker compose exec -T postgres psql -U malio inventory_prod < /tmp/inventory.sql # Creer les tables manquantes (si le dump a des erreurs de syntaxe) cd /var/www/inventory docker compose exec -u www-data app php bin/console doctrine:schema:update --force --env=prod # Nettoyer rm /tmp/inventory.sql ``` ### Structure finale du dossier ``` /var/www/inventory/ ├── docker-compose.yml ├── deploy.sh ├── .env └── uploads/ ``` --- ## Deployer une nouvelle version Quand l'app est deja installee, deployer une mise a jour : ```bash cd /var/www/inventory ./deploy.sh # deploie la derniere version (latest) ./deploy.sh v1.9.4 # deploie une version specifique ``` C'est tout. Le script pull l'image, redemarre le conteneur, lance les migrations et vide le cache. --- ## Rollback ### Image seule (pas de changement de schema BDD) ```bash ./deploy.sh v1.9.3 ``` ### Avec rollback de migration ```bash # 1. Rollback schema (pendant que la version actuelle tourne encore) docker compose exec -T -u www-data app php bin/console doctrine:migrations:migrate prev --no-interaction # 2. Deployer l'ancienne version ./deploy.sh v1.9.3 ``` --- ## CI/CD Le workflow `.gitea/workflows/build-docker.yml` se declenche automatiquement sur push de tag `v*` : 1. Build l'image multi-stage (inclut checkout des submodules pour le frontend) 2. Push vers `gitea.malio.fr/malio-dev/inventory:` et `:latest` --- ## Voir les logs ```bash cd /var/www/inventory docker compose logs -f # tous les logs docker compose logs -f --tail=100 # 100 dernieres lignes ``` Logs Symfony : ```bash docker compose exec app cat var/log/prod.log ``` --- ## Migration depuis l'ancien deploiement (bare-metal) Si l'application tourne deja en bare metal : 1. Installer Docker (voir pre-requis) 2. Creer le dossier `/var/www/inventory-docker/` (ne pas ecraser l'ancien) 3. Copier les fichiers existants : ```bash cp /var/www/inventory/.env /var/www/inventory-docker/.env cp -a /var/www/inventory/var/uploads /var/www/inventory-docker/uploads ``` 4. Creer `docker-compose.yml` et `deploy.sh` dans `/var/www/inventory-docker/` (voir etape 4 ci-dessus) 5. Editer `/var/www/inventory-docker/.env` : changer `DATABASE_URL` pour utiliser `host.docker.internal` au lieu de `127.0.0.1` 6. Se connecter au registry Gitea (voir etape 3 ci-dessus) 7. Mettre a jour Nginx systeme avec la conf reverse proxy (voir etape 7 ci-dessus) 8. Arreter l'ancien PHP-FPM/Apache : `sudo systemctl stop php8.4-fpm` ou `sudo systemctl stop apache2` 9. Deployer : `cd /var/www/inventory-docker && ./deploy.sh` 10. Verifier que tout marche, puis renommer le dossier : `mv /var/www/inventory-docker /var/www/inventory`