Files
Starseed/doc/prompt-rename-prod.md
Matthieu cacd8718e5
Some checks failed
Auto Tag Develop / tag (push) Has been cancelled
chore(prod) : ajuster conf prod pour HTTP en reseau local
- .env.prod.example : JWT_COOKIE_SECURE=0, CORS_ALLOW_ORIGIN en http
- prompt-rename-prod.md : retirer etape certbot/Let's Encrypt, verifier la resolution locale a la place
- deployment-docker.md : aligner DEFAULT_URI, CORS et JWT_COOKIE_SECURE sur HTTP
2026-05-19 08:38:03 +02:00

7.9 KiB

Prompt — Migration prod Coltura -> Starseed

Copier-coller integralement dans une session Claude lancee sur le serveur de prod apres que :

  • le push develop + build CI ont publie l'image gitea.malio.fr/malio-dev/starseed:latest,
  • la resolution reseau local (DNS interne ou /etc/hosts des postes clients) pour starseed.malio-dev.fr est en place.

Setup : HTTP en reseau local, pas de TLS. Pas de Let's Encrypt.


Prompt a fournir au Claude prod

Tu es sur le serveur de production d'une app Symfony+Nuxt qui s'appelait Coltura et qui doit etre renommee en Starseed. Le rename cote code est deja fait et merge. Le repo Gitea s'appelle deja starseed. L'image gitea.malio.fr/malio-dev/starseed:latest est publiee.

L'app est servie en HTTP sur reseau local (pas de TLS, pas de Let's Encrypt). La resolution starseed.malio-dev.fr est faite via DNS interne ou /etc/hosts cote postes clients — pas de certificat a gerer.

Objectif : basculer la prod sur le nouveau nom (registry, container, DB, path FS, vhost) sans perdre les donnees et avec downtime minimal (mode maintenance pendant la migration).

Etat actuel a verifier en premier (donne-moi le retour de chaque commande avant de continuer) :

# 1. Container actuel + image
sudo docker ps --filter name=coltura-app --format 'table {{.Names}}\t{{.Image}}\t{{.Status}}'

# 2. DB existante
sudo -u postgres psql -c "\l" | grep -E "coltura|starseed"

# 3. Path FS app
ls -la /var/www/coltura/ 2>/dev/null | head -5
ls -la /var/www/starseed/ 2>/dev/null | head -5

# 4. Vhost nginx system
sudo ls -la /etc/nginx/sites-enabled/ | grep -E "coltura|starseed"

Apres confirmation de l'etat, executer dans cet ordre, en demandant validation utilisateur AVANT chaque etape destructive (DB drop, rm -rf, certificat) :

Etape 1 — Mode maintenance

cd /var/www/coltura
touch maintenance.on
# Verifier qu'une requete renvoie 503
curl -s -o /dev/null -w "HTTP %{http_code}\n" http://coltura.malio-dev.fr/

Doit renvoyer 503.

Etape 2 — Backup DB (CRITIQUE — ne pas skipper)

BACKUP_FILE="/root/coltura_prod_backup_$(date +%Y%m%d_%H%M%S).sql"
sudo -u postgres pg_dump -F c -f "$BACKUP_FILE" coltura_prod
ls -lh "$BACKUP_FILE"

Stocker ce chemin — il sera utilise pour le rollback.

Etape 3 — Creer la DB cible et migrer

Recuperer l'owner et le user de connexion actuels :

sudo -u postgres psql -c "\l coltura_prod"
grep DATABASE_URL /var/www/coltura/.env

Puis (adapter l'owner si different de malio) :

sudo -u postgres psql <<'SQL'
CREATE DATABASE starseed_prod OWNER malio;
SQL

sudo -u postgres pg_dump coltura_prod | sudo -u postgres psql starseed_prod
sudo -u postgres psql starseed_prod -c "\dt" | head -20

Verifier que les tables sont bien copiees. Si le user PG s'appelle coltura, le renommer ou en creer un starseed est OPTIONNEL — la connexion peut continuer avec coltura tant que GRANT est OK. Confirmer avec l'utilisateur s'il veut renommer le role PG :

# Optionnel : renommer le role PG (si user de connexion s'appelle 'coltura')
# sudo -u postgres psql -c "ALTER ROLE coltura RENAME TO starseed;"

Etape 4 — Renommer le path FS

sudo mv /var/www/coltura /var/www/starseed
# Verifier le contenu
sudo ls -la /var/www/starseed/ | head -10
# Verifier que .env existe encore
sudo test -f /var/www/starseed/.env && echo ".env OK"

Etape 5 — Mettre a jour .env de prod

Editer /var/www/starseed/.env :

  • DATABASE_URL : remplacer /coltura_prod -> /starseed_prod (et user si renomme a etape 3)
  • CORS_ALLOW_ORIGIN : remplacer coltura.malio-dev.fr -> starseed.malio-dev.fr
  • DEFAULT_URI : http://starseed.malio-dev.fr
  • JWT_COOKIE_SECURE : doit etre 0 (HTTP, pas de TLS) — verifier qu'il l'est deja

Diff attendu :

- DATABASE_URL="postgresql://malio:xxx@host.docker.internal:5432/coltura_prod?..."
+ DATABASE_URL="postgresql://malio:xxx@host.docker.internal:5432/starseed_prod?..."
- CORS_ALLOW_ORIGIN='^http://coltura\.malio-dev\.fr$'
+ CORS_ALLOW_ORIGIN='^http://starseed\.malio-dev\.fr$'
- DEFAULT_URI=http://coltura.malio-dev.fr
+ DEFAULT_URI=http://starseed.malio-dev.fr

Etape 6 — Stopper et supprimer l'ancien container

cd /var/www/starseed
sudo docker compose down
# Verifier qu'il n'y a plus de coltura-app
sudo docker ps -a --filter name=coltura

Etape 7 — Pull la nouvelle image et demarrer

Le docker-compose.prod.yml du dossier deja a jour pointe sur gitea.malio.fr/malio-dev/starseed:latest et container_name: starseed-app.

cd /var/www/starseed
sudo docker compose pull
sudo docker compose up -d
sleep 5
sudo docker ps --filter name=starseed-app
sudo docker logs starseed-app --tail 30

Etape 8 — Migrations Doctrine + cache

cd /var/www/starseed
sudo docker compose exec -T -u www-data app php bin/console doctrine:migrations:migrate --no-interaction
sudo docker compose exec -T -u www-data app php bin/console cache:clear --env=prod
sudo docker compose exec -T -u www-data app php bin/console cache:warmup --env=prod

Etape 9 — Vhost nginx system (HTTP only)

Copier le nouveau vhost (a jour avec server_name starseed.malio-dev.fr et root /var/www/starseed/public, listen 80 uniquement) :

sudo cp /var/www/starseed/infra/prod/nginx-proxy.conf /etc/nginx/sites-available/starseed.conf
sudo ln -sf /etc/nginx/sites-available/starseed.conf /etc/nginx/sites-enabled/starseed.conf
sudo rm -f /etc/nginx/sites-enabled/coltura.conf
sudo nginx -t

Verifier la resolution reseau local avant reload :

getent hosts starseed.malio-dev.fr || echo "ATTENTION : starseed.malio-dev.fr ne resout pas localement"

Puis :

sudo systemctl reload nginx

Etape 10 — Desactiver le mode maintenance et tester

rm -f /var/www/starseed/maintenance.on

# Tests externes (HTTP local)
curl -s -o /dev/null -w "HTTP %{http_code}\n" http://starseed.malio-dev.fr/
curl -s http://starseed.malio-dev.fr/api/version

/api/version doit renvoyer du JSON avec la version courante.

Etape 11 — Cleanup (apres 24-48h de stabilite)

A faire plus tard, seulement quand on est sur que tout marche :

# Backup deja conserve en /root/coltura_prod_backup_*.sql.
# Apres validation utilisateur :
sudo -u postgres psql -c "DROP DATABASE coltura_prod;"
sudo rm -f /etc/nginx/sites-available/coltura.conf
sudo docker image prune  # nettoie les vieilles images coltura

Rollback (si echec apres etape 5)

# 1. Remettre maintenance
touch /var/www/starseed/maintenance.on 2>/dev/null || touch /var/www/coltura/maintenance.on

# 2. Restaurer le path FS
sudo mv /var/www/starseed /var/www/coltura 2>/dev/null || true

# 3. Restaurer le vhost coltura
sudo rm -f /etc/nginx/sites-enabled/starseed.conf
sudo ln -sf /etc/nginx/sites-available/coltura.conf /etc/nginx/sites-enabled/coltura.conf
sudo systemctl reload nginx

# 4. Redemarrer l'ancien container (l'image coltura est encore dans le registry)
cd /var/www/coltura
# Editer docker-compose.prod.yml pour pointer sur coltura:latest si necessaire
sudo docker compose up -d

# 5. Si la DB starseed_prod a ete modifiee, restaurer depuis le backup
sudo -u postgres psql -c "DROP DATABASE IF EXISTS coltura_prod;"
sudo -u postgres pg_restore -C -d postgres "$BACKUP_FILE"

# 6. Lever maintenance
rm -f /var/www/coltura/maintenance.on

Regles de comportement pour le Claude prod

  • Ne jamais skipper le backup (etape 2).
  • Demander confirmation utilisateur avant : DROP DATABASE, rm -rf, et avant de lever le mode maintenance final.
  • Une seule operation destructive a la fois, attendre le retour utilisateur entre chaque.
  • Logger systematiquement la sortie des commandes critiques (pg_dump, docker compose up, nginx -t / reload).
  • Si une etape echoue, NE PAS continuer — declencher le rollback.
  • Ne commit rien sur le repo depuis le serveur prod.