27 lines
1014 B
Markdown
27 lines
1014 B
Markdown
|
|
# Polish: Deployment Pipeline
|
||
|
|
|
||
|
|
## Pre-Deploy Checks
|
||
|
|
Add to deploy-to-target.sh: SSH key exists, target reachable, 2GB free disk space.
|
||
|
|
|
||
|
|
## Backup Before Deploy
|
||
|
|
```bash
|
||
|
|
sudo cp /usr/local/bin/archipelago /usr/local/bin/archipelago.backup
|
||
|
|
sudo cp -a /opt/archipelago/web-ui /opt/archipelago/web-ui.backup
|
||
|
|
sudo cp /etc/nginx/sites-available/archipelago /etc/nginx/sites-available/archipelago.backup
|
||
|
|
```
|
||
|
|
|
||
|
|
## Health Check After Deploy
|
||
|
|
Loop up to 15 attempts, 2s apart, checking `curl http://localhost:5678/health` returns 200.
|
||
|
|
|
||
|
|
## Rollback on Failure
|
||
|
|
If health check fails: restore binary, frontend, nginx from .backup files, restart services.
|
||
|
|
|
||
|
|
## Deployment Lock
|
||
|
|
Use `flock` on `/tmp/archipelago-deploy.lock` to prevent concurrent deploys.
|
||
|
|
|
||
|
|
## Nginx Validation
|
||
|
|
Always `sudo nginx -t` before reload. If invalid, restore backup config.
|
||
|
|
|
||
|
|
## Integration Flow
|
||
|
|
1. acquire_lock → 2. pre_deploy_checks → 3. backup_current → 4. build + deploy → 5. validate_nginx → 6. restart services → 7. health_check || rollback
|