Files
Mangarr/deploy.php
ext.jeremy.guillot@maxicoffee.domains f418b36167
All checks were successful
Deploy / deploy (push) Successful in 3m21s
fix: clear Symfony cache before container restart on deploy
The var/ directory is a persistent Docker volume. Without explicit cache:clear,
docker restart keeps serving old cached routes (e.g. / → MangaController).
New code is already visible via bind mount before restart, so docker exec works.

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
2026-03-11 20:17:43 +01:00

68 lines
3.3 KiB
PHP

<?php
namespace Deployer;
require 'recipe/symfony.php';
// GITEA_TOKEN injecté depuis le secret Gitea (scope: read:repository)
$giteaToken = getenv('GITEA_TOKEN') ?: throw new \RuntimeException('GITEA_TOKEN secret is required');
set('repository', "https://{$giteaToken}@git.homelab.nestor-server.fr/colgora/Mangarr.git");
set('keep_releases', 3);
set('composer_options', '--no-dev --optimize-autoloader --no-interaction --prefer-dist --ignore-platform-reqs --no-scripts');
// Copier vendor/ et node_modules/ depuis la release précédente (hard links, quasi instantané)
// Composer et npm ne mettent à jour que ce qui a changé → déploiements beaucoup plus rapides
set('copy_dirs', ['vendor', 'node_modules']);
// Pas de shared_files ni shared_dirs : tout est géré par les volumes Docker
set('shared_files', []);
set('shared_dirs', []);
set('writable_dirs', []);
host('production')
->set('hostname', getenv('DEPLOY_HOST')) // Injecté depuis le secret Gitea
->set('remote_user', 'deploy') // User avec accès docker group
->set('deploy_path', '/srv/mangarr')
->set('branch', 'main');
// Créer les dossiers que Docker doit monter comme volumes (gitignorés, absents de la release)
task('deploy:prepare_dirs', function () {
run('mkdir -p {{release_path}}/var {{release_path}}/public/images {{release_path}}/public/cbz {{release_path}}/public/tmp');
});
// composer install via container éphémère (pas de PHP sur l'hôte requis)
// --user assure que vendor/ appartient au user deploy et non root
task('deploy:vendors', function () {
run('docker run --rm --user $(id -u):$(id -g) -v {{release_path}}:/app -w /app composer:2 install {{composer_options}}');
});
// Build assets via container node éphémère
// Le cache webpack (node_modules/.cache) est persisté dans shared/webpack_cache entre les releases
// → 1er build lent, suivants compilent uniquement les modules modifiés
desc('Build Webpack Encore assets');
task('webpack_encore:build', function () {
run('mkdir -p /srv/mangarr/shared/webpack_cache');
run('docker run --rm --user $(id -u):$(id -g) -e npm_config_cache=/tmp/npm-cache -e PUPPETEER_SKIP_DOWNLOAD=1 -v {{release_path}}:/app -v /srv/mangarr/shared/webpack_cache:/app/node_modules/.cache -w /app node:22-alpine sh -c "npm install && npm run build"');
});
// Restart Docker containers (entrypoint gère les migrations automatiquement)
// cache:clear avant restart : le nouveau code est déjà visible via bind mount,
// mais var/ est un volume Docker persistant qui garde l'ancien cache Symfony.
desc('Restart Docker containers');
task('docker:restart', function () {
run('docker exec mangarr php bin/console cache:clear --env=prod');
run('docker restart mangarr-worker-commands mangarr-worker-events mangarr-worker-scheduler');
run('docker restart mangarr');
});
// Pas de PHP sur l'hôte : désactiver les tâches Symfony qui en ont besoin
// Le cache et les migrations sont gérés par l'entrypoint.sh au démarrage du container
task('deploy:cache:clear', function () {});
task('deploy:cache:warmup', function () {});
// Hooks
after('deploy:update_code', 'deploy:prepare_dirs');
after('deploy:prepare_dirs', 'deploy:copy_dirs');
after('deploy:vendors', 'webpack_encore:build');
after('deploy:symlink', 'docker:restart');
after('deploy:failed', 'deploy:unlock');